/* ==================== 国际化 Teal 设计系统 ==================== */
:root {
  /* 全站品牌主色：墨绿色 */
  --primary: #0D9488;
  --primary-hover: #0F766E;
  --primary-light: #CCFBF1;
  --primary-lighter: #F0FDFA;
  --primary-gradient-end: #14B8A6;
  --secondary: #0D9488;
  --secondary-hover: #0F766E;
  --secondary-light: #CCFBF1;
  --accent: #10B981;
  --accent-light: #D1FAE5;
  --warning: #F59E0B;
  --warning-light: #FEF3C7;
  --danger: #EF4444;
  --danger-light: #FEE2E2;
  --telegram: #0EA5E9;
  --wechat: #16A34A;
  --whatsapp: #25D366;
  --bg-primary: #F8F9FA;
  --bg-secondary: #F1F5F9;
  --bg-tertiary: #E2E8F0;
  --card: #FFFFFF;
  --card-hover: #FFFFFF;
  --text-primary: #1E293B;
  --text-secondary: #64748B;
  --text-tertiary: #94A3B8;
  --text-inverse: #FFFFFF;
  --border: #E2E8F0;
  --border-light: #F1F5F9;
  --border-focus: #0D9488;
  --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.04);
  --shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.04), 0 1px 2px rgba(0, 0, 0, 0.02);
  --shadow-md: 0 4px 8px rgba(0, 0, 0, 0.04), 0 2px 4px rgba(0, 0, 0, 0.02);
  --shadow-lg: 0 12px 24px rgba(0, 0, 0, 0.06), 0 4px 8px rgba(0, 0, 0, 0.03);
  --shadow-xl: 0 20px 40px rgba(0, 0, 0, 0.08), 0 8px 16px rgba(0, 0, 0, 0.04);
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --radius-full: 9999px;
  --transition-fast: all 0.15s ease;
  --transition: all 0.2s ease;
  --transition-slow: all 0.3s ease;
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 12px;
  --space-lg: 16px;
  --space-xl: 20px;
  --space-2xl: 24px;
  --space-3xl: 32px;
  --font-family: 'Inter', 'Segoe UI', 'SF Pro Text', 'PingFang SC', 'Noto Sans SC', 'Microsoft YaHei', 'Helvetica Neue', Arial, -apple-system, BlinkMacSystemFont, sans-serif;
  --font-size-xs: 12px;
  --font-size-sm: 13px;
  --font-size-md: 14px;
  --font-size-lg: 15px;
  --font-size-xl: 16px;
  --font-size-2xl: 18px;
  --font-size-3xl: 20px;
  --font-weight-regular: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  --line-height-tight: 1.35;
  --line-height-normal: 1.5;
  --line-height-relaxed: 1.65;
  --letter-spacing-tight: -0.01em;
  --letter-spacing-normal: 0;
  --letter-spacing-wide: 0.02em;
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
}

/* Points ledger page: cleaner, international-style list hierarchy */
#pointsLedgerList {
  display: grid;
  gap: 10px;
}

.points-ledger-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 12px 14px;
  box-shadow: var(--shadow-xs);
}

.points-ledger-main {
  min-width: 0;
}

.points-ledger-title {
  margin: 0;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.35;
  word-break: break-word;
}

.points-ledger-time {
  margin: 4px 0 0;
  font-size: 12px;
  color: var(--text-tertiary);
  line-height: 1.2;
}

.points-ledger-delta {
  flex-shrink: 0;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
}

.points-ledger-delta.is-plus {
  color: #0f766e;
  background: #dcfce7;
}

.points-ledger-delta.is-minus {
  color: #b91c1c;
  background: #fee2e2;
}

.points-ledger-delta.is-neutral {
  color: var(--text-secondary);
  background: var(--bg-secondary);
}

.points-ledger-empty-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 18px 14px;
  text-align: center;
}

.points-ledger-empty-title {
  margin: 0;
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
}

.points-ledger-empty-sub {
  margin: 8px 0 0;
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.4;
}

.points-ledger-summary-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  background: linear-gradient(135deg, #e8fbf8 0%, #f2fcfb 100%);
  border: 1px solid #bdeee7;
  border-radius: 14px;
  padding: 14px;
}

.points-ledger-summary-main {
  min-width: 0;
}

.points-ledger-summary-label {
  margin: 0;
  font-size: 12px;
  color: #0f766e;
}

.points-ledger-summary-value {
  margin: 4px 0 0;
  font-size: 22px;
  font-weight: 800;
  color: #0f766e;
  line-height: 1;
}

.points-ledger-summary-side {
  display: grid;
  gap: 6px;
}

.points-ledger-summary-chip {
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  text-align: center;
}

.points-ledger-summary-chip.is-plus {
  color: #0f766e;
  background: #dcfce7;
}

.points-ledger-summary-chip.is-minus {
  color: #b91c1c;
  background: #fee2e2;
}

.points-ledger-filter-bar {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 2px;
}

.points-ledger-filter-chip {
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--text-secondary);
  border-radius: 999px;
  padding: 6px 12px;
  font-size: 12px;
  font-weight: 600;
  white-space: nowrap;
}

.points-ledger-filter-chip.is-active {
  border-color: #14b8a6;
  background: #14b8a6;
  color: #fff;
}

.points-ledger-group-title {
  margin-top: 6px;
  margin-bottom: 2px;
  font-size: 12px;
  font-weight: 700;
  color: var(--text-tertiary);
}

.my-interactions-main {
  padding-bottom: 20px;
}

.my-interactions-toolbar {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}

.my-interactions-export-btn {
  min-height: 34px;
  padding: 0 12px;
  font-size: 12px;
  border-radius: 10px;
  font-weight: 700;
}

.my-interactions-sort-box {
  display: flex;
  align-items: center;
  gap: 8px;
}

.my-interactions-list {
  display: grid;
  gap: 10px;
}

.my-interactions-summary-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.my-interactions-summary-card {
  background: #ffffff;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 14px;
  padding: 10px 12px;
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.04);
}

.my-interactions-summary-label {
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 700;
  color: var(--text-secondary);
}
.my-interactions-summary-label i {
  color: var(--primary, #0d9488);
  font-size: 11px;
}

.my-interactions-summary-value {
  margin: 6px 0 0;
  font-size: 22px;
  line-height: 1;
  font-weight: 800;
  color: var(--text-primary, #0f172a);
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1;
}

.my-interactions-card {
  border-radius: 16px;
  border: 1px solid var(--border, #e2e8f0);
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.05);
  padding: 13px 12px;
}

.my-interactions-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.my-interactions-tag {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  min-height: 24px;
  padding: 0 10px;
  font-size: 11px;
  font-weight: 700;
  color: #0f766e;
  background: #dcfce7;
}
.my-interactions-tag--likes {
  background: #dcfce7;
  color: #166534;
}
.my-interactions-tag--downvotes {
  background: #fee2e2;
  color: #991b1b;
}
.my-interactions-tag--arbitration {
  background: #ede9fe;
  color: #5b21b6;
}
.my-interactions-tag--reports {
  background: #fef3c7;
  color: #92400e;
}

.my-interactions-view-btn {
  min-height: 30px;
  padding: 0 10px;
  font-size: 12px;
  border-radius: 10px;
  font-weight: 700;
}

.my-interactions-title {
  margin: 8px 0 0;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.35;
  color: var(--text-primary);
}

.my-interactions-sub {
  margin: 6px 0 0;
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.4;
}

.my-interactions-time {
  margin: 6px 0 0;
  font-size: 11px;
  color: var(--text-tertiary);
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1;
}

.my-interactions-empty {
  text-align: center;
  border-radius: 14px;
  padding: 16px 12px;
}

.my-interactions-empty-title {
  margin: 0;
  font-size: 15px;
  font-weight: 700;
}

.my-interactions-empty-sub {
  margin: 8px 0 0;
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.45;
}

/* 字体加载优化（单条声明即可，避免重复解析） */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: local('Inter');
}

@media (prefers-color-scheme: dark) {
  :root {
    --bg-primary: #0F172A;
    --bg-secondary: #1E293B;
    --bg-tertiary: #334155;
    --card: #1E293B;
    --card-hover: #263548;
    --text-primary: #F1F5F9;
    --text-secondary: #94A3B8;
    --text-tertiary: #64748B;
    --border: #334155;
    --border-light: #1E293B;
  }
  
  /* 暗黑模式底部导航 */
  .bottom-nav {
    background: rgba(15, 23, 42, 0.98);
    border-top-color: var(--border);
    box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.3);
  }
  
  .nav-item:hover {
    background: var(--bg-tertiary);
  }
  
  /* 暗黑模式悬浮按钮 */
  .publish-fab {
    box-shadow: 0 8px 24px rgba(249, 115, 22, 0.5), 0 4px 12px rgba(0, 0, 0, 0.3);
  }
  
  .publish-fab:hover {
    box-shadow: 0 12px 32px rgba(249, 115, 22, 0.6), 0 6px 16px rgba(0, 0, 0, 0.4);
  }
  
  /* 暗黑模式分享按钮 */
  .share-btn.telegram {
    background: linear-gradient(135deg, rgba(14, 165, 233, 0.2) 0%, rgba(14, 165, 233, 0.3) 100%);
    box-shadow: 0 2px 8px rgba(14, 165, 233, 0.2);
  }
  
  .share-btn.wechat {
    background: linear-gradient(135deg, rgba(22, 163, 74, 0.2) 0%, rgba(22, 163, 74, 0.3) 100%);
    box-shadow: 0 2px 8px rgba(22, 163, 74, 0.2);
  }
  
  .share-btn.whatsapp {
    background: linear-gradient(135deg, rgba(37, 211, 102, 0.2) 0%, rgba(37, 211, 102, 0.3) 100%);
    box-shadow: 0 2px 8px rgba(37, 211, 102, 0.2);
  }
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { font-size: 16px; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body { font-family: var(--font-family); font-size: var(--font-size-md); font-weight: var(--font-weight-regular); background: var(--bg-primary); color: var(--text-primary); line-height: var(--line-height-normal); min-height: 100vh; padding-bottom: calc(108px + var(--safe-bottom)); overflow-x: hidden; -webkit-overflow-scrolling: touch; text-rendering: optimizeLegibility; -webkit-tap-highlight-color: transparent; letter-spacing: var(--letter-spacing-normal); }

/* ==================== 全局字体层级系统（仅字体相关） ==================== */
h1, .page-title, .logo-text { font-size: var(--font-size-2xl); font-weight: var(--font-weight-bold); line-height: var(--line-height-tight); letter-spacing: var(--letter-spacing-tight); }
h2, .modal-title, .section-title, .card-title, .guide-post-title, .menu-title { font-size: var(--font-size-xl); font-weight: var(--font-weight-semibold); line-height: var(--line-height-tight); }
h3, .guide-comment-header h3, .guide-user-name, .my-comment-guide { font-size: var(--font-size-lg); font-weight: var(--font-weight-semibold); line-height: var(--line-height-normal); }
p, .card-desc, .guide-post-content, .guide-comment-content, .menu-desc, .form-label, .tab-item, .search-input, .form-input, .form-select, .form-textarea { font-size: var(--font-size-md); line-height: var(--line-height-relaxed); font-weight: var(--font-weight-regular); }
button, .btn, .search-btn, .guide-filter-btn, .nav-label, .tag, .vip-tag { font-family: var(--font-family); font-size: var(--font-size-sm); font-weight: var(--font-weight-semibold); line-height: var(--line-height-normal); }
.card-price, .price-value, .member-level-value { font-size: var(--font-size-2xl); font-weight: var(--font-weight-bold); line-height: var(--line-height-tight); letter-spacing: var(--letter-spacing-tight); }
.card-meta, .guide-post-time, .guide-comment-time, .my-comment-meta, .meta-text, .region-item .currency, .category-name, .region-btn .arrow, .guide-modal-tip { font-size: var(--font-size-xs); font-weight: var(--font-weight-regular); line-height: var(--line-height-normal); color: var(--text-tertiary); }
.nav-label { font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold); letter-spacing: var(--letter-spacing-wide); }
.tag, .vip-tag { font-size: var(--font-size-xs); }
.guide-post-stat, .guide-comment-author { font-size: var(--font-size-sm); }

@media (max-width: 768px) {
  :root {
    --font-size-lg: 14px;
    --font-size-xl: 15px;
    --font-size-2xl: 17px;
    --font-size-3xl: 18px;
    --line-height-relaxed: 1.6;
  }
}

/* 可访问性：焦点状态 */
*:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; }
button:focus-visible, a:focus-visible, input:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; }

/* 减少动画偏好 */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

.container { max-width: 480px; margin: 0 auto; padding: 0 var(--space-lg); }
@media (min-width: 768px) { .container { max-width: 600px; } }
@media (min-width: 1024px) { .container { max-width: 800px; } }

.header { position: sticky; top: 0; background: rgba(248, 250, 252, 0.95); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); padding: 10px 0; border-bottom: 1px solid var(--border-light); z-index: 100; will-change: transform; }
.header-content { display: flex; justify-content: space-between; align-items: center; gap: var(--space-md); }
.header-left { display: flex; align-items: center; gap: var(--space-md); }
/* 详情 / 租房列表 / 分类列表顶栏：桌面 sticky 顶栏用；移动端见 @media (max-width:768px) 内单独处理，避免外层 flex 与子区 main.container 宽度基线不一致 */
#listingDetailPage .header > .container,
#rentalListPage .header > .container,
#categoryListPage .header > .container {
  min-width: 0;
}
#listingDetailPage .header .header-left,
#rentalListPage .header .header-left,
#categoryListPage .header .header-left {
  flex: 0 1 auto;
  min-width: 0;
  justify-content: flex-start;
}
#listingDetailPage .header .logo-text,
#rentalListPage .header .logo-text,
#categoryListPage .header .logo-text {
  text-align: left;
  flex: 0 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.back-btn { font-size: 24px; cursor: pointer; transition: var(--transition); color: var(--text-primary); background: none; border: none; padding: 4px; border-radius: var(--radius-sm); display: none !important; }
.back-btn:hover { background: var(--bg-secondary); }
.back-btn:active { transform: scale(0.9); }
.back-btn:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; }
.logo { display: flex; align-items: center; gap: 10px; }
.logo-icon { width: 32px; height: 32px; background: linear-gradient(135deg, var(--primary) 0%, var(--primary-gradient-end) 100%); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; color: white; font-weight: 700; font-size: 16px; box-shadow: var(--shadow-sm); }
.logo-text { font-size: 18px; font-weight: 700; color: var(--text-primary); letter-spacing: -0.02em; }
.header-right { display: flex; align-items: center; gap: 8px; }
.header-trailing { display: flex; align-items: center; gap: 8px; }

.region-selector { position: relative; }
.region-btn { 
  display: inline-grid; 
  grid-template-columns: auto auto auto;
  justify-content: center;
  align-items: center; 
  gap: 4px; 
  height: 36px;
  padding: 0 9px;
  min-width: 0;
  width: auto;
  background: var(--primary-light); 
  color: var(--primary); 
  border: none; 
  border-radius: var(--radius-full); 
  font-size: 13px; 
  font-weight: 600; 
  cursor: pointer; 
  transition: var(--transition);
  white-space: nowrap;
}
.region-btn:hover { 
  background: var(--primary); 
  color: white; 
}
.region-btn:active { 
  transform: scale(0.96); 
}
.region-btn:focus-visible { 
  outline: 2px solid var(--primary); 
  outline-offset: 2px; 
}
.region-btn .flag { 
  width: 18px;
  text-align: center;
  font-size: 15px;
  line-height: 1;
  display: inline-block;
}
.region-btn .region-code { 
  font-weight: 700; 
  letter-spacing: 0.03em;
  font-size: 12px;
  color: inherit;
  padding: 1px 6px;
  border-radius: 9999px;
  background: rgba(22, 93, 255, 0.12);
}
.region-btn .region-name { 
  font-weight: 500;
  font-size: 12px;
  color: inherit;
  text-align: center;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.region-btn .arrow { 
  font-size: var(--font-size-xs); 
  transition: transform 0.2s;
  margin-left: 0;
  opacity: 0.7;
}
.region-selector.active .region-btn .arrow { 
  transform: rotate(180deg); 
}

/* 顶栏城市：与地区按钮同风格的胶囊 + 自定义下拉 */
.city-selector { position: relative; }
.city-btn {
  display: inline-grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 6px;
  height: 36px;
  padding: 0 12px;
  min-width: 126px;
  max-width: 168px;
  background: var(--primary-light);
  color: var(--primary);
  border: none;
  border-radius: var(--radius-full);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition);
  white-space: nowrap;
}
.city-btn:hover {
  background: var(--primary);
  color: white;
}
.city-btn:active {
  transform: scale(0.96);
}
.city-btn:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}
.city-btn .city-btn-label {
  font-weight: 500;
  font-size: 12px;
  color: inherit;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: left;
}
.city-btn .arrow {
  font-size: var(--font-size-xs);
  transition: transform 0.2s;
  opacity: 0.7;
  flex-shrink: 0;
}
.city-selector.active .city-btn .arrow {
  transform: rotate(180deg);
}
.city-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 100%;
  width: max-content;
  max-width: min(300px, 88vw);
  max-height: 300px;
  overflow-y: auto;
  background: var(--card);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--border);
  display: none;
  z-index: 1001;
  -webkit-overflow-scrolling: touch;
}
.city-dropdown.show {
  display: block;
  animation: slideDown 0.2s ease;
}
.city-dropdown-item {
  display: block;
  width: 100%;
  text-align: left;
  padding: 12px 14px;
  border: none;
  border-bottom: 1px solid var(--border-light);
  background: transparent;
  font-size: 14px;
  font-weight: 500;
  color: var(--text-primary);
  cursor: pointer;
  transition: var(--transition);
}
.city-dropdown-item:last-child {
  border-bottom: none;
}
.city-dropdown-item:hover {
  background: var(--bg-secondary);
}
.city-dropdown-item.active {
  background: var(--primary-lighter);
  color: var(--primary);
  font-weight: 600;
}

.region-dropdown { position: absolute; top: calc(100% + 8px); right: 0; background: var(--card); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); min-width: 220px; max-width: min(280px, calc(100vw - 24px)); max-height: min(320px, 58vh); overflow-y: auto; display: none; z-index: 1000; border: 1px solid var(--border); -webkit-overflow-scrolling: touch; }
.region-dropdown.show { display: block; animation: slideDown 0.2s ease; }
@keyframes slideDown { from { opacity: 0; transform: translateY(-10px); } to { opacity: 1; transform: translateY(0); } }
@keyframes regionDropdownHomeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
.region-item { padding: 8px 12px; display: flex; align-items: center; gap: 8px; cursor: pointer; transition: var(--transition); border-bottom: 1px solid var(--border-light); }
.region-item:last-child { border-bottom: none; }
.region-item:active { background: var(--bg-secondary); }
.region-item.active { background: var(--primary-lighter); }
.region-item .flag { font-size: 24px; }
.region-dropdown .region-item .flag {
  width: 20px;
  font-size: 15px;
  text-align: center;
  flex-shrink: 0;
}
.region-item .info { flex: 1; min-width: 0; }
.region-item .name { font-weight: 600; font-size: 13px; color: var(--text-primary); line-height: 1.25; }
.region-item .currency { font-size: 11px; color: var(--text-secondary); line-height: 1.2; }
.region-item .check { color: var(--primary); font-size: 15px; flex-shrink: 0; }

/* 首页国家下拉：与攻略页国家下拉视觉保持一致 */
#homePage .region-selector .region-dropdown {
  left: 0;
  right: auto;
  transform: none;
  top: calc(100% + 6px);
  width: auto;
  min-width: 180px;
  max-width: min(220px, calc(100vw - 28px));
  max-height: 320px;
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
  border: none;
  padding: 8px;
}
#homePage .region-selector .region-dropdown .region-item {
  border-bottom: none;
  border-radius: 10px;
  padding: 8px 12px;
  gap: 8px;
}
#homePage .region-selector .region-dropdown .region-item:hover {
  background: #F8FAFC;
}
#homePage .region-selector .region-dropdown .region-item.active {
  background: #ECFDF5;
}
#homePage .region-selector .region-dropdown .region-item .name {
  font-size: 13px;
  line-height: 1.2;
}
#homePage .region-selector .region-dropdown .region-item .currency {
  font-size: 12px;
}
.region-city-panel {
  display: none;
  padding: 10px 12px 12px;
  border-top: 1px solid var(--border-light);
  background: var(--bg-primary);
}
.region-city-panel.show { display: block; }
.region-city-panel-title {
  font-size: 12px;
  color: var(--text-secondary);
  margin-bottom: 8px;
}
.region-city-panel-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  max-height: 132px;
  overflow-y: auto;
}
.region-city-pill {
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 12px;
  color: var(--text-secondary);
  cursor: pointer;
}
.region-city-pill.active {
  border-color: var(--primary);
  background: var(--primary-lighter);
  color: var(--primary);
}

.lang-btn { padding: 8px 14px; background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-full); font-size: 13px; font-weight: 500; color: var(--text-secondary); cursor: pointer; transition: var(--transition); }
.lang-btn { height: 36px; display: inline-flex; align-items: center; justify-content: center; padding: 0 14px; line-height: 1; }
.lang-btn:hover { background: var(--bg-secondary); border-color: var(--primary); color: var(--primary); }
.lang-btn:active { background: var(--bg-secondary); }
.lang-btn:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; }
/* Language entry is now centralized in the settings language panel. */
button.lang-btn[onclick*="toggleLang"] { display: none !important; }
.search-section { margin-bottom: var(--space-2xl); }
.search-wrapper { position: relative; }
.search-box { display: flex; align-items: center; gap: 12px; background: var(--card); border: 2px solid var(--border); border-radius: var(--radius-xl); padding: 14px 18px; transition: var(--transition); box-shadow: var(--shadow-xs); }
.search-box:focus-within { border-color: var(--primary); box-shadow: 0 0 0 4px var(--primary-light); }
.search-icon { color: var(--text-tertiary); font-size: 18px; flex-shrink: 0; }
.search-input {
  flex: 1;
  border: none !important;
  outline: none;
  box-shadow: none !important;
  font-size: 15px;
  background: transparent !important;
  color: var(--text-primary);
  font-family: var(--font-family);
  padding: 0;
  -webkit-appearance: none;
  appearance: none;
}
.search-input:focus {
  border: none !important;
  outline: none;
  box-shadow: none !important;
  background: transparent !important;
}
.search-input::placeholder { color: var(--text-tertiary); }
/* WebKit 对 type=search 会自带清除/装饰，与自定义 .search-clear 叠成两个 × */
.search-input[type="search"]::-webkit-search-cancel-button,
.search-input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
  appearance: none;
  display: none;
  width: 0;
  height: 0;
  margin: 0;
  padding: 0;
  pointer-events: none;
}
.search-input[type="search"]::-moz-search-clear-button {
  display: none;
}
.search-clear { color: var(--text-tertiary); cursor: pointer; font-size: 20px; display: none; transition: var(--transition); background: none; border: none; }
.search-input:not(:placeholder-shown) ~ .search-clear { display: block; }
.search-btn { padding: 8px 18px; background: var(--primary); color: white; border: none; border-radius: var(--radius-full); font-size: 14px; font-weight: 600; cursor: pointer; transition: var(--transition); }
.search-btn:active { transform: scale(0.95); }

.search-panel { position: absolute; top: calc(100% + 4px); left: 0; right: 0; background: var(--card); border-radius: 0 0 var(--radius-xl) var(--radius-xl); box-shadow: var(--shadow-lg); max-height: 400px; overflow-y: auto; display: none; z-index: 1001; border: 1px solid var(--border); }
.search-panel.show { display: block; }
.search-history { padding: var(--space-lg); border-bottom: 1px solid var(--border-light); }
.search-history-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.search-history-title { font-size: 13px; color: var(--text-secondary); font-weight: 500; }
.search-history-clear { font-size: 12px; color: var(--primary); cursor: pointer; font-weight: 600; }
.search-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.search-tag { padding: 6px 14px; background: var(--bg-secondary); border-radius: var(--radius-full); font-size: 13px; cursor: pointer; transition: var(--transition); border: 1px solid var(--border); }
.search-tag:hover { background: var(--primary-light); border-color: var(--primary); color: var(--primary); }
.search-tag:active { background: var(--primary); color: white; }
.search-tag:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; }
.search-hot { padding: var(--space-lg); }
.search-hot-title { font-size: 13px; color: var(--text-secondary); font-weight: 500; margin-bottom: 12px; }

/* 首页搜索+AI并排模块 */
.home-search-ai-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-bottom: 12px;
  align-items: stretch;
}
.home-search-col {
  min-width: 0;
  order: 1;
}
.search-icon {
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  border-radius: 9999px;
  background: var(--primary-lighter);
  color: var(--primary);
}

.tip-banner { background: linear-gradient(135deg, var(--primary-lighter) 0%, var(--primary-light) 100%); border-radius: var(--radius-lg); padding: 14px 16px; display: flex; align-items: center; gap: 10px; margin-bottom: var(--space-2xl); }
.tip-icon { font-size: 18px; flex-shrink: 0; }
.tip-text { font-size: 13px; color: var(--primary-hover); font-weight: 500; line-height: 1.5; }
.warning-banner { background: var(--warning-light); border-radius: var(--radius-lg); padding: 14px 16px; display: flex; align-items: flex-start; gap: 10px; margin-bottom: var(--space-2xl); border-left: 4px solid var(--warning); }
.warning-banner .tip-icon { color: var(--warning); }
.warning-banner .tip-text { color: var(--text-secondary); font-size: 13px; line-height: 1.6; }
.privacy-banner { background: var(--accent-light); border-radius: var(--radius-lg); padding: 14px 16px; display: flex; align-items: flex-start; gap: 10px; margin-bottom: var(--space-2xl); border-left: 4px solid var(--accent); }
.privacy-banner .tip-icon { color: var(--accent); }
.privacy-banner .tip-text { color: var(--text-secondary); font-size: 13px; line-height: 1.6; }
.success-banner { background: var(--accent-light); border-radius: var(--radius-lg); padding: 14px 16px; margin-bottom: var(--space-2xl); border-left: 4px solid var(--accent); }
.success-banner h4 { color: var(--accent); font-size: 15px; font-weight: 700; margin-bottom: 6px; }
.success-banner p { color: var(--text-secondary); font-size: 13px; }

/* 【Bug修复2】统一中英文分类网格布局 - 优化为4列布局 */
.category-section { margin-bottom: var(--space-3xl); }
.category-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.category-item { display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 12px 8px; background: var(--card); border-radius: var(--radius-lg); cursor: pointer; transition: var(--transition); border: 1px solid transparent; }
.category-item:hover { border-color: var(--primary); box-shadow: var(--shadow-md); transform: translateY(-2px); }
.category-item.active { border-color: var(--primary); background: var(--primary-lighter); box-shadow: var(--shadow-sm); }
.category-item:active { transform: scale(0.95); }
.category-item:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; }
.category-icon { width: 44px; height: 44px; background: linear-gradient(135deg, var(--primary) 0%, var(--primary-gradient-end) 100%); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; color: white; font-size: 20px; transition: var(--transition); }
.category-item:active .category-icon { transform: scale(1.05); }
.category-icon.house { background: linear-gradient(135deg, var(--primary) 0%, var(--primary-gradient-end) 100%); }
.category-icon.job { background: linear-gradient(135deg, var(--primary) 0%, var(--primary-gradient-end) 100%); }
.category-icon.secondhand { background: linear-gradient(135deg, var(--primary) 0%, var(--primary-gradient-end) 100%); }
.category-icon.service { background: linear-gradient(135deg, var(--primary) 0%, var(--primary-gradient-end) 100%); }
.category-icon.guide { background: linear-gradient(135deg, var(--primary) 0%, var(--primary-gradient-end) 100%); }
.category-icon.daigou { background: linear-gradient(135deg, var(--primary) 0%, var(--primary-gradient-end) 100%); }
.category-icon.ai { background: linear-gradient(135deg, var(--primary) 0%, var(--primary-gradient-end) 100%); }
.category-name { font-size: 12px; font-weight: 500; color: var(--text-primary); text-align: center; }

.ai-banner { background: linear-gradient(135deg, var(--primary) 0%, var(--primary-gradient-end) 100%); border-radius: var(--radius-xl); padding: var(--space-lg); color: var(--text-inverse); margin-bottom: var(--space-lg); }
.ai-banner-title { font-size: var(--font-size-xl); font-weight: var(--font-weight-bold); margin-bottom: 6px; }
.ai-banner-desc { font-size: var(--font-size-md); opacity: 0.9; margin-bottom: var(--space-sm); }
.ai-banner-btn { display: inline-flex; align-items: center; gap: 6px; padding: 8px 16px; background: #fff; color: var(--primary); border: none; border-radius: var(--radius-full); font-size: var(--font-size-sm); font-weight: var(--font-weight-semibold); cursor: pointer; transition: var(--transition); box-shadow: var(--shadow-sm); }
.ai-banner-btn:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.ai-banner-btn:active { transform: scale(0.95); }
.ai-banner-btn:focus-visible { outline: 2px solid white; outline-offset: 2px; }

.vip-swiper-section { margin-bottom: 16px; }
.vip-swiper { position: relative; width: 100%; height: 140px; border-radius: 20px; overflow: hidden; box-shadow: var(--shadow-md); }
.vip-swiper-wrapper { display: flex; width: 100%; height: 100%; transition: transform 0.3s ease; }
.vip-swiper-item { flex-shrink: 0; width: 100%; height: 100%; position: relative; }
.vip-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.vip-swiper-item::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0, 0, 0, 0.26), rgba(0, 0, 0, 0.04)); }
.vip-tag { display: none; }
.vip-title { position: absolute; bottom: 12px; left: 16px; right: auto; color: var(--text-inverse); font-size: 13px; font-weight: 700; z-index: 1; text-shadow: 0 2px 8px rgba(0, 0, 0, 0.45); background: rgba(0, 0, 0, 0.3); padding: 4px 12px; border-radius: 40px; backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); white-space: nowrap; max-width: calc(100% - 88px); overflow: hidden; text-overflow: ellipsis; }
.vip-dots { position: absolute; bottom: 8px; right: 16px; left: auto; display: flex; justify-content: flex-end; gap: 6px; z-index: 1; }
.vip-dot { width: 6px; height: 6px; border-radius: 3px; background: rgba(255, 255, 255, 0.5); }
.vip-dot.active { width: 16px; background: var(--text-inverse); }

.tab-section { margin-bottom: var(--space-xl); }
.tab-nav { display: flex; gap: 8px; overflow-x: auto; padding-bottom: 4px; scrollbar-width: none; -webkit-overflow-scrolling: touch; }
.tab-nav::-webkit-scrollbar { display: none; }
.tab-item { flex-shrink: 0; padding: 10px 18px; background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-full); font-size: 14px; font-weight: 500; color: var(--text-secondary); cursor: pointer; transition: var(--transition); white-space: nowrap; }
.tab-item:hover { background: var(--bg-secondary); border-color: var(--primary); color: var(--primary); }
.tab-item:active { background: var(--bg-secondary); }
.tab-item.active { background: var(--primary); border-color: var(--primary); color: white; }
.tab-item:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; }

/* 首页分类标签：贴合轻量胶囊视觉 */
#homePage .tab-nav {
  padding-bottom: 6px;
  gap: 10px;
}
#homePage .tab-item {
  padding: 7px 15px;
  font-size: 13px;
  border-radius: 40px;
  background: #eef2f6;
  border-color: #eef2f6;
  color: var(--text-primary);
}
#homePage .tab-item.active {
  background: var(--primary);
  border-color: var(--primary);
  color: var(--text-inverse);
}

#homePage .home-tab-scrollbar {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 8px;
  margin-top: 2px;
  margin-bottom: 2px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
}

#homePage .tab-section.is-overflowing .home-tab-scrollbar {
  opacity: 1;
  pointer-events: auto;
}

#homePage .home-tab-scroll-arrow {
  font-size: 10px;
  color: #9ca3af;
  line-height: 1;
  user-select: none;
  cursor: pointer;
  transition: color 0.2s ease;
}

#homePage .home-tab-scroll-arrow.is-disabled {
  color: #d1d5db;
  cursor: default;
}

#homePage .home-tab-scroll-track {
  display: block;
  height: 8px;
  border-radius: 999px;
  background: #e5e7eb;
  overflow: hidden;
}

#homePage .home-tab-scroll-thumb {
  display: block;
  width: 42%;
  height: 100%;
  border-radius: inherit;
  background: #9ca3af;
  transition: transform 0.16s ease, width 0.16s ease;
}

.home-filter-item {
  display: inline-flex;
  align-items: center;
  gap: 0;
}

.tab-nav.is-overflowing {
  cursor: grab;
}

.tab-nav.is-overflowing:active {
  cursor: grabbing;
}

.content-card { background: var(--card); border-radius: var(--radius-xl); padding: 12px; margin-bottom: 12px; border: 1px solid var(--border); transition: var(--transition); box-shadow: var(--shadow-xs); }
.content-card:hover { box-shadow: var(--shadow-md); border-color: var(--primary-light); }
.content-card:active { transform: scale(0.99); }
.card-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; margin-bottom: 8px; }
.card-title { font-size: 15px; font-weight: 600; color: var(--text-primary); line-height: 1.4; flex: 1; }
.card-price { font-size: 16px; font-weight: 700; color: var(--secondary); white-space: nowrap; }
.card-tags { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 8px; }
.tag { padding: 3px 10px; background: var(--primary-light); color: var(--primary); border-radius: var(--radius-full); font-size: var(--font-size-xs); font-weight: var(--font-weight-medium); }
.tag.hot { background: var(--warning-light); color: #B45309; }
.tag.new { background: var(--accent-light); color: var(--accent); }
.card-images { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; margin: 8px 0; border-radius: var(--radius-md); overflow: hidden; }
.card-images img { 
  width: 100%; 
  max-height: 200px;
  aspect-ratio: 3/2; 
  object-fit: cover; 
  background: var(--bg-secondary);
  border-radius: var(--radius-sm);
  display: block;
  /* 移动端适配 */
  @media (max-width: 768px) {
    max-height: 150px;
    aspect-ratio: 4/3;
  }
}
/* 图片加载失败时的占位符样式 */
.card-images img::before {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background: var(--bg-secondary);
}
.card-desc { 
    font-size: 13px; 
    color: var(--text-secondary); 
    line-height: 1.5; 
    margin-bottom: 8px; 
    display: -webkit-box; 
    display: box; /* 标准属性 */
    -webkit-line-clamp: 2; 
    line-clamp: 2; /* 标准属性 */
    -webkit-box-orient: vertical; 
    box-orient: vertical; /* 标准属性 */
    overflow: hidden; 
}

.contact-section { margin-top: 12px; }
.contact-btn { display: inline-flex; align-items: center; gap: 6px; padding: 10px 16px; background: var(--primary-light); color: var(--primary); border: none; border-radius: var(--radius-md); font-size: 14px; font-weight: 600; cursor: pointer; transition: var(--transition); }
.contact-btn:hover { background: var(--primary); color: white; }
.contact-btn:active { background: var(--primary); color: white; }
.contact-btn:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; }
.contact-info { margin-top: 12px; padding: 14px; background: var(--bg-secondary); border-radius: var(--radius-md); font-size: 14px; color: var(--text-primary); line-height: 1.8; display: none; }
.contact-info.show { display: block; animation: fadeIn 0.3s ease; }
.contact-locked { display: block; border: 1px dashed var(--border); }
.contact-unlock-actions { margin-top: 10px; display: flex; gap: 8px; flex-wrap: wrap; }
.contact-fraud-warning { margin-bottom: 8px; font-size: 12px; color: var(--danger); background: var(--danger-light); padding: 8px; border-radius: 8px; }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

.card-footer { display: flex; justify-content: space-between; align-items: center; padding-top: 12px; border-top: 1px solid var(--border-light); margin-top: 12px; }
.card-meta { display: flex; align-items: center; gap: 12px; font-size: 12px; color: var(--text-tertiary); }
.card-actions { display: flex; align-items: center; gap: 16px; }
.native-share-bar { display: inline-flex; align-items: center; flex-wrap: wrap; gap: 8px; margin-right: 4px; }
.native-share-label { font-size: 12px; font-weight: 500; color: var(--text-tertiary); white-space: nowrap; }
.native-share-btn { width: 32px; height: 32px; border: 1px solid var(--border-light); background: var(--bg-secondary); border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; color: var(--text-secondary); cursor: pointer; }
.native-share-btn:hover { color: var(--primary); border-color: var(--primary-light); }
.action-btn { display: flex; align-items: center; gap: 4px; font-size: 13px; color: var(--text-secondary); cursor: pointer; transition: var(--transition); background: none; border: none; padding: 4px 0; font-weight: 500; border-radius: var(--radius-sm); }
.action-btn:hover { color: var(--primary); background: var(--primary-lighter); }
.action-btn:active { color: var(--primary); }
.action-btn.active { color: var(--danger); }
.action-btn.favorited { color: var(--danger); }
.favorite-icon { font-size: 14px; line-height: 1; color: currentColor; }
.favorite-text { color: currentColor; }
.action-btn:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; }

/* 举报模态框样式 */
.report-reasons {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.report-reason-item {
  display: flex;
  align-items: center;
}

.report-label {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: 14px;
  color: var(--text-primary);
  cursor: pointer;
  width: 100%;
  padding: var(--space-sm);
  border-radius: var(--radius-md);
  transition: var(--transition);
}

.report-label:hover {
  background: var(--bg-secondary);
}

.report-label input[type="radio"] {
  accent-color: var(--primary);
  width: 16px;
  height: 16px;
  cursor: pointer;
}

/* 【Bug修复3】优化分享按钮样式 */
.share-section { margin-top: 16px; padding-top: 12px; border-top: 1px solid var(--border-light); }
.share-label { font-size: 12px; color: var(--text-tertiary); margin-bottom: 10px; font-weight: 500; }
.share-group { 
  display: flex; 
  gap: 12px;
  justify-content: center;
}

.share-btn { 
  width: 48px; 
  height: 48px; 
  border-radius: var(--radius-lg); 
  display: flex; 
  align-items: center; 
  justify-content: center; 
  cursor: pointer; 
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); 
  border: none;
  position: relative;
  overflow: hidden;
}

.share-btn svg {
  width: 24px;
  height: 24px;
  transition: transform 0.3s ease;
}

/* Telegram 品牌色 */
.share-btn.telegram { 
  background: linear-gradient(135deg, #E0F2FE 0%, #BAE6FD 100%); 
  color: #0EA5E9;
  box-shadow: 0 2px 8px rgba(14, 165, 233, 0.15);
}

.share-btn.telegram:hover { 
  background: linear-gradient(135deg, #0EA5E9 0%, #0284C7 100%); 
  color: white; 
  transform: translateY(-3px) scale(1.05);
  box-shadow: 0 6px 16px rgba(14, 165, 233, 0.3);
}

.share-btn.telegram:hover svg {
  transform: scale(1.1);
}

.share-btn.telegram:active { 
  background: linear-gradient(135deg, #0284C7 0%, #0369A1 100%); 
  color: white;
  transform: translateY(-1px) scale(0.98);
}

/* WeChat 品牌色 */
.share-btn.wechat { 
  background: linear-gradient(135deg, #DCFCE7 0%, #BBF7D0 100%); 
  color: #16A34A;
  box-shadow: 0 2px 8px rgba(22, 163, 74, 0.15);
}

.share-btn.wechat:hover { 
  background: linear-gradient(135deg, #16A34A 0%, #15803D 100%); 
  color: white; 
  transform: translateY(-3px) scale(1.05);
  box-shadow: 0 6px 16px rgba(22, 163, 74, 0.3);
}

.share-btn.wechat:hover svg {
  transform: scale(1.1);
}

.share-btn.wechat:active { 
  background: linear-gradient(135deg, #15803D 0%, #166534 100%); 
  color: white;
  transform: translateY(-1px) scale(0.98);
}

/* WhatsApp 品牌色 */
.share-btn.whatsapp { 
  background: linear-gradient(135deg, #DCFCE7 0%, #BBF7D0 100%); 
  color: #25D366;
  box-shadow: 0 2px 8px rgba(37, 211, 102, 0.15);
}

.share-btn.whatsapp:hover { 
  background: linear-gradient(135deg, #25D366 0%, #22C55E 100%); 
  color: white; 
  transform: translateY(-3px) scale(1.05);
  box-shadow: 0 6px 16px rgba(37, 211, 102, 0.3);
}

.share-btn.whatsapp:hover svg {
  transform: scale(1.1);
}

.share-btn.whatsapp:active { 
  background: linear-gradient(135deg, #22C55E 0%, #16A34A 100%); 
  color: white;
  transform: translateY(-1px) scale(0.98);
}

.share-btn:focus-visible { 
  outline: 2px solid var(--primary); 
  outline-offset: 2px;
}

.empty-state { text-align: center; padding: 60px var(--space-2xl); background: var(--card); border-radius: var(--radius-xl); border: 1px solid var(--border); }
.empty-icon { font-size: 56px; margin-bottom: 16px; }
.empty-title { font-size: 18px; font-weight: 600; color: var(--text-primary); margin-bottom: 8px; }
.empty-desc { font-size: 14px; color: var(--text-secondary); margin-bottom: var(--space-2xl); }
.empty-btn { display: inline-block; padding: 12px 24px; background: var(--primary); color: white; border-radius: var(--radius-md); font-size: 14px; font-weight: 600; cursor: pointer; transition: var(--transition); border: none; }
.empty-btn:active { transform: scale(0.95); }

/* ==================== 底部导航优化 ==================== */
.bottom-nav { 
  position: fixed; 
  bottom: 0; 
  left: 0; 
  right: 0; 
  background: rgba(255, 255, 255, 0.98); 
  backdrop-filter: blur(20px); 
  -webkit-backdrop-filter: blur(20px); 
  display: flex; 
  justify-content: space-around; 
  align-items: center;
  padding: 6px 0 calc(20px + var(--safe-bottom)); 
  border-top: 1px solid var(--border-light); 
  z-index: 100; 
  box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.08);
}

.nav-item { 
  display: flex; 
  flex-direction: column; 
  align-items: center; 
  justify-content: center;
  gap: 3px; 
  padding: 6px 8px; 
  cursor: pointer; 
  transition: var(--transition); 
  background: none; 
  border: none; 
  border-radius: var(--radius-md); 
  min-width: 64px;
  position: relative;
}

.nav-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%) scaleX(0);
  width: 40px;
  height: 3px;
  background: var(--primary);
  border-radius: 0 0 4px 4px;
  transition: transform 0.3s ease;
}

.nav-item.active::before {
  transform: translateX(-50%) scaleX(1);
}

.nav-item:hover { 
  background: var(--bg-secondary); 
}

.nav-icon { 
  font-size: 24px; 
  color: var(--text-tertiary); 
  transition: var(--transition); 
  line-height: 1;
}

.nav-label { 
  font-size: var(--font-size-xs); 
  font-weight: var(--font-weight-semibold); 
  color: var(--text-tertiary); 
  white-space: nowrap;
  letter-spacing: 0.3px;
}

.nav-item.active .nav-icon, 
.nav-item.active .nav-label { 
  color: var(--primary); 
  font-weight: 700;
}

.nav-item:active .nav-icon, 
.nav-item:active .nav-label { 
  color: var(--primary-hover); 
  transform: scale(0.9);
}

.nav-item:focus-visible { 
  outline: 2px solid var(--primary); 
  outline-offset: 2px; 
}

/* ==================== 悬浮发布按钮优化 ==================== */
.publish-fab { 
  position: fixed; 
  right: 20px; 
  bottom: calc(85px + var(--safe-bottom)); 
  width: 60px; 
  height: 60px; 
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-gradient-end) 100%); 
  border-radius: 50%; 
  display: flex; 
  align-items: center; 
  justify-content: center; 
  color: white; 
  font-size: 32px; 
  font-weight: 300;
  cursor: pointer; 
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); 
  border: none; 
  box-shadow: 0 8px 24px rgba(249, 115, 22, 0.4), 0 4px 12px rgba(0, 0, 0, 0.15);
  z-index: 99; 
  overflow: hidden;
}

.publish-fab::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.3);
  transform: translate(-50%, -50%);
  transition: width 0.6s, height 0.6s;
}

.publish-fab:hover::before {
  width: 100%;
  height: 100%;
}

.publish-fab:hover { 
  transform: translateY(-4px) scale(1.05); 
  box-shadow: 0 12px 32px rgba(249, 115, 22, 0.5), 0 6px 16px rgba(0, 0, 0, 0.2);
}

.publish-fab:active { 
  transform: translateY(-2px) scale(0.95); 
  box-shadow: 0 4px 12px rgba(249, 115, 22, 0.3);
}

.publish-fab:focus-visible { 
  outline: 3px solid var(--secondary); 
  outline-offset: 4px; 
}

.page { display: none; animation: fadeIn 0.3s ease; }
.page.active { display: block; }

.form-group { margin-bottom: var(--space-2xl); }
.form-label { display: block; font-size: 14px; font-weight: 600; color: var(--text-primary); margin-bottom: 8px; }
.form-label-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
}
.form-label-row .form-label {
  margin-bottom: 0;
  flex: 1;
  min-width: 0;
}
.form-label-muted {
  font-weight: 500;
  color: var(--text-tertiary);
  font-size: 12px;
}
.form-char-count {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-tertiary);
  flex-shrink: 0;
  font-variant-numeric: tabular-nums;
}
.form-char-count.is-over {
  color: var(--danger);
}
.form-hint-tight {
  font-size: 12px;
  color: var(--text-secondary);
  margin: 0 0 8px;
  line-height: 1.45;
}
.publish-ai-tools {
  margin-bottom: var(--space-xl);
  padding: 12px 14px;
  background: var(--bg-secondary);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
}
.publish-ai-tools-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 6px;
}
.publish-ai-tools-desc {
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.5;
  margin: 0 0 10px;
}
.publish-ai-tools-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 8px;
}
.publish-ai-tools-actions .btn-sm {
  padding: 8px 14px;
  font-size: 13px;
}
.publish-ai-result {
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.45;
  min-height: 1.2em;
}

.form-input { width: 100%; padding: 14px 16px; background: var(--bg-secondary); border: 2px solid transparent; border-radius: var(--radius-md); font-size: 15px; color: var(--text-primary); transition: var(--transition); font-family: var(--font-family); }
.form-input:focus { outline: none; background: var(--card); border-color: var(--primary); box-shadow: 0 0 0 4px var(--primary-light); }
.form-input::placeholder { color: var(--text-tertiary); }
.form-select { width: 100%; padding: 14px 16px; background: var(--bg-secondary); border: 2px solid transparent; border-radius: var(--radius-md); font-size: 15px; color: var(--text-primary); cursor: pointer; transition: var(--transition); font-family: var(--font-family); appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; background-size: 20px; }
.form-select:focus { outline: none; background-color: var(--card); border-color: var(--primary); }
.form-textarea { width: 100%; padding: 14px 16px; background: var(--bg-secondary); border: 2px solid transparent; border-radius: var(--radius-md); font-size: 15px; color: var(--text-primary); min-height: 120px; resize: none; transition: var(--transition); font-family: var(--font-family); line-height: 1.6; }
.form-textarea:focus { outline: none; background: var(--card); border-color: var(--primary); }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 14px 24px; border-radius: var(--radius-md); font-size: 15px; font-weight: 600; cursor: pointer; transition: var(--transition); border: none; font-family: var(--font-family); }
.btn-primary { background: var(--primary); color: white; }
.btn-primary:hover { background: var(--primary-hover); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn-primary:active { transform: scale(0.98); }
.btn-primary:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; }
.btn-secondary { background: var(--bg-secondary); color: var(--text-primary); }
.btn-secondary:hover { background: var(--bg-tertiary); }
.btn-secondary:active { background: var(--bg-tertiary); }
.btn-secondary:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; }

.guide-publish-scope-banner {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 10px 12px;
  padding: 12px 14px;
  margin-bottom: var(--space-lg);
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, var(--primary-lighter) 0%, var(--warning-light) 100%);
  border: 1px solid var(--border);
}

.guide-publish-scope-text {
  flex: 1 1 220px;
  margin: 0;
  font-size: 13px;
  line-height: 1.55;
  color: var(--text-primary);
}

.guide-publish-go-info-btn {
  flex-shrink: 0;
  white-space: nowrap;
}

.guide-publish-fields-wrap {
  transition: opacity 0.2s ease;
}

.guide-publish-fields--locked {
  opacity: 0.42;
  pointer-events: none;
  user-select: none;
}

.guide-publish-lock-hint {
  margin: 0 0 var(--space-md);
  font-size: 12px;
  line-height: 1.45;
  color: var(--text-tertiary);
}
.btn-danger { background: var(--danger); color: white; }
.btn-danger:hover { background: #DC2626; }
.btn-danger:focus-visible { outline: 2px solid var(--danger); outline-offset: 2px; }
.btn-warning { background: var(--warning); color: white; }
.btn-warning:hover { background: #D97706; }
.btn-warning:focus-visible { outline: 2px solid var(--warning); outline-offset: 2px; }
.btn-full { width: 100%; }
.btn-group { display: flex; gap: 12px; margin: var(--space-lg) 0; }

.ai-tools-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin-bottom: var(--space-2xl); }
.ai-tool-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: var(--space-lg); cursor: pointer; transition: var(--transition); }
.ai-tool-card:active { border-color: var(--primary); }
.ai-tool-card.active { border-color: var(--primary); background: var(--primary-lighter); }
.ai-tool-icon { width: 40px; height: 40px; background: linear-gradient(135deg, var(--primary) 0%, var(--primary-gradient-end) 100%); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; color: white; font-size: 18px; margin-bottom: 10px; }
.ai-tool-name { font-size: 14px; font-weight: 600; color: var(--text-primary); margin-bottom: 4px; }
.ai-tool-desc { font-size: 12px; color: var(--text-secondary); }
.ai-result-box { background: var(--bg-secondary); border-radius: var(--radius-md); padding: 18px; min-height: 140px; font-size: 14px; line-height: 1.7; white-space: pre-wrap; color: var(--text-primary); border: 1px solid var(--border); }

.file-upload-area { border: 2px dashed var(--border); border-radius: var(--radius-lg); padding: 30px var(--space-2xl); text-align: center; cursor: pointer; transition: var(--transition); background: var(--bg-secondary); margin-bottom: var(--space-lg); }
.file-upload-area:active { border-color: var(--primary); background: var(--primary-lighter); }
.file-upload-icon { font-size: 36px; margin-bottom: 10px; }
.file-upload-text { font-size: 14px; color: var(--text-secondary); margin-bottom: 6px; }
.file-upload-tip { font-size: 12px; color: var(--text-tertiary); }
.file-list { margin-top: var(--space-lg); }
.file-item { display: flex; align-items: center; justify-content: space-between; padding: 12px; background: var(--bg-secondary); border-radius: var(--radius-md); margin-bottom: 8px; }
.file-item-left { display: flex; align-items: center; gap: 10px; }
.file-icon { width: 36px; height: 36px; background: linear-gradient(135deg, var(--primary) 0%, var(--primary-gradient-end) 100%); border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; color: white; font-size: 16px; }
.file-name { font-size: 14px; font-weight: 500; }
.file-size { font-size: 12px; color: var(--text-secondary); }
.file-del-btn { color: var(--danger); cursor: pointer; font-size: 14px; font-weight: 600; }

.user-card { background: var(--card); border-radius: var(--radius-xl); padding: var(--space-2xl); text-align: center; border: 1px solid var(--border); margin-bottom: var(--space-2xl); }
.user-avatar { width: 80px; height: 80px; background: linear-gradient(135deg, var(--primary) 0%, var(--primary-gradient-end) 100%); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: white; font-size: 32px; font-weight: 700; margin: 0 auto 12px; box-shadow: var(--shadow-md); }
.user-name { font-size: 20px; font-weight: 700; color: var(--text-primary); margin-bottom: 4px; }
.user-id { font-size: 12px; color: var(--text-tertiary); margin-bottom: 12px; }
.vip-badge { display: inline-flex; align-items: center; gap: 6px; padding: 6px 14px; background: linear-gradient(135deg, #F59E0B 0%, #FBBF24 100%); color: white; border-radius: var(--radius-full); font-size: 13px; font-weight: 600; }
.user-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: var(--space-2xl); padding-top: var(--space-2xl); border-top: 1px solid var(--border-light); }
.stat-item { text-align: center; }
.stat-value { font-size: 24px; font-weight: 700; color: var(--primary); margin-bottom: 4px; }
.stat-label { font-size: 12px; color: var(--text-secondary); }

.menu-list { background: var(--card); border-radius: var(--radius-xl); border: 1px solid var(--border); overflow: hidden; margin-bottom: var(--space-2xl); }
.menu-item { padding: 16px var(--space-2xl); display: flex; justify-content: space-between; align-items: center; cursor: pointer; transition: var(--transition); border-bottom: 1px solid var(--border-light); }
.menu-item:last-child { border-bottom: none; }
.menu-item:active { background: var(--bg-secondary); }
.menu-item-content { flex: 1; }
.menu-item-title { font-size: 15px; font-weight: 600; color: var(--text-primary); margin-bottom: 2px; }
.menu-item-desc { font-size: 12px; color: var(--text-secondary); }
.menu-item-arrow { color: var(--text-tertiary); font-size: 18px; }

.modal-overlay { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(15, 23, 42, 0.6); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); display: none; align-items: center; justify-content: center; padding: var(--space-2xl); z-index: 1000; }
.modal-overlay.show { display: flex; }
.modal-content { background: var(--card); border-radius: var(--radius-xl); padding: var(--space-2xl); max-width: 400px; width: 100%; max-height: 80vh; overflow-y: auto; box-shadow: var(--shadow-xl); -webkit-overflow-scrolling: touch; }
.modal-overlay#publishModal .modal-content { max-width: 640px; max-height: 92vh; }
/* 发布信息：避免正文区高度算错裁切底部「上一步 / 下一步」；覆盖通用 .modal-content 的 overflow-y:auto */
.modal-overlay#publishModal .modal-content.publish-info-v2 {
    max-height: min(92vh, 860px);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    box-sizing: border-box;
}
.modal-overlay#publishModal .modal-content.publish-info-v2 .modal-header {
    flex-shrink: 0;
}
.modal-overlay#publishModal .modal-content.publish-info-v2 .modal-body-scroll {
    flex: 1 1 auto;
    min-height: 0;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}
.modal-overlay#guideDetailModal.show { z-index: 1100; }
.modal-overlay#gcv2ArbitrateModal.show {
  z-index: 2600;
}
.modal-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-2xl); }
.modal-title { font-size: 18px; font-weight: 700; color: var(--text-primary); }
.modal-close { width: 32px; height: 32px; background: var(--bg-secondary); border: none; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 18px; color: var(--text-secondary); cursor: pointer; transition: var(--transition); }
.modal-close:active { background: var(--bg-tertiary); }
.lang-picker-modal { max-width: 420px; }
.lang-picker-current { margin: -8px 0 12px; font-size: 13px; color: var(--text-secondary); }
.lang-pill-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.lang-pill {
  min-height: 42px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--bg-secondary);
  color: var(--text-primary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 0 12px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition);
}
.lang-pill:hover { border-color: var(--primary-light); background: #fff; }
.lang-pill:active { transform: scale(0.98); }
.lang-pill.active {
  border-color: var(--primary);
  background: var(--primary-lighter);
  color: var(--primary);
}
.lang-pill-pending { border-style: dashed; color: var(--text-secondary); }
.lang-pill-tag {
  font-size: 10px;
  padding: 1px 6px;
  border-radius: 999px;
  background: #E2E8F0;
  color: #475569;
}
.lang-picker-note { margin: 12px 0 0; font-size: 12px; color: var(--text-tertiary); line-height: 1.5; }

.checkbox-group { display: flex; flex-direction: column; gap: 12px; }
.checkbox-item { display: flex; align-items: center; gap: 10px; padding: 12px 14px; background: var(--bg-secondary); border-radius: var(--radius-md); cursor: pointer; transition: var(--transition); }
.checkbox-item:active { background: var(--bg-tertiary); }
.checkbox-item input { width: 18px; height: 18px; cursor: pointer; }
.checkbox-item label { font-size: 14px; color: var(--text-primary); cursor: pointer; flex: 1; }
.checkbox-item:has(input:checked) { background: var(--primary-lighter); }
.promise-checkbox { display: flex; align-items: center; gap: 10px; margin: var(--space-2xl) 0; padding: 14px; background: var(--warning-light); border-radius: var(--radius-md); border-left: 4px solid var(--warning); }
.promise-checkbox input { width: 18px; height: 18px; cursor: pointer; }
.promise-checkbox label { font-size: 14px; color: var(--text-primary); cursor: pointer; line-height: 1.5; flex: 1; }

.pay-feature-bar { background: linear-gradient(135deg, var(--primary-lighter) 0%, var(--secondary-light) 100%); border-radius: var(--radius-xl); padding: var(--space-2xl); margin-bottom: var(--space-2xl); border: 1px solid rgba(22, 93, 255, 0.15); }
.pay-feature-title { font-size: 16px; font-weight: 700; margin-bottom: 14px; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 10px; }
.free-count-tip { font-size: 12px; color: var(--accent); background: var(--accent-light); padding: 4px 12px; border-radius: var(--radius-full); }
.pay-feature-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.pay-feature-item { background: var(--card); border-radius: var(--radius-md); padding: var(--space-lg); cursor: pointer; transition: var(--transition); border: 1px solid var(--border); }
.pay-feature-item:active { border-color: var(--primary); }
.pay-feature-icon { font-size: 22px; margin-bottom: 8px; }
.pay-feature-name { font-size: 14px; font-weight: 600; margin-bottom: 4px; color: var(--text-primary); }
.pay-feature-price { font-size: 13px; color: var(--secondary); font-weight: 600; }

.pay-option { padding: 16px; border: 2px solid var(--border); border-radius: var(--radius-md); margin-bottom: 12px; cursor: pointer; transition: var(--transition); display: flex; align-items: center; gap: 14px; }
.pay-option:active { border-color: var(--primary); }
.pay-option.active { border-color: var(--primary); background: var(--primary-lighter); }
.pay-icon { width: 44px; height: 44px; border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; font-size: 22px; background: linear-gradient(135deg, var(--primary) 0%, var(--primary-gradient-end) 100%); color: white; }
.pay-info { flex: 1; }
.pay-info h4 { font-size: 15px; font-weight: 700; margin-bottom: 4px; }
.pay-info p { font-size: 12px; color: var(--text-secondary); }
.pay-price { font-size: 18px; font-weight: 700; color: var(--secondary); margin-left: auto; }
.vip-tag { padding: 3px 8px; background: var(--warning); color: white; border-radius: 6px; font-size: var(--font-size-xs); margin-left: 8px; font-weight: var(--font-weight-semibold); }

/* 【Bug修复5】修复图片上传网格样式 */
.img-upload-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin: var(--space-xl) 0; }
.upload-item { width: 100%; aspect-ratio: 1; border: 2px dashed var(--primary); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; font-size: 28px; color: var(--primary); cursor: pointer; background: var(--primary-lighter); position: relative; transition: var(--transition); overflow: hidden; }
.upload-item:active { border-color: var(--secondary); background: rgba(249, 115, 22, 0.05); }
.upload-item img { width: 100%; height: 100%; object-fit: cover; }
.upload-item .del-btn { position: absolute; top: -8px; right: -8px; width: 24px; height: 24px; background: var(--danger); color: white; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 14px; cursor: pointer; box-shadow: var(--shadow-sm); border: none; }
.upload-tip { font-size: 12px; color: var(--text-tertiary); margin-top: 8px; }

.role-switch { display: flex; gap: 8px; margin: var(--space-2xl) 0; flex-wrap: wrap; }
.role-btn { padding: 10px 18px; background: var(--bg-secondary); border: 2px solid var(--border); border-radius: var(--radius-md); font-size: 13px; cursor: pointer; transition: var(--transition); font-weight: 600; }
.role-btn:active { border-color: var(--primary); }
.role-btn.active { background: var(--primary); color: white; border-color: var(--primary); }
.role-panel { margin: var(--space-2xl) 0; padding: var(--space-2xl); background: var(--card); border-radius: var(--radius-lg); border: 1px solid var(--border); display: none; }
.role-panel.show { display: block; }
.role-panel h3 { font-size: 18px; margin-bottom: var(--space-2xl); font-weight: 700; }

.auth-module { margin: var(--space-2xl) 0; padding: var(--space-2xl); background: var(--card); border-radius: var(--radius-lg); border: 2px dashed var(--primary); display: none; }
.auth-module.show { display: block; }
.auth-title { font-size: 16px; font-weight: 700; margin-bottom: 8px; text-align: center; color: var(--text-primary); }
.auth-desc { font-size: 13px; color: var(--text-secondary); text-align: center; margin-bottom: var(--space-2xl); line-height: 1.6; }

/* 【Bug修复5】修复积分兑换按钮对齐问题 */
.point-exchange-module { margin: var(--space-2xl) 0; padding: var(--space-2xl); background: var(--card); border-radius: var(--radius-lg); border: 1px solid var(--border); }
.point-exchange-title { font-size: 16px; font-weight: 700; margin-bottom: var(--space-lg); }
.point-exchange-list { display: flex; flex-direction: column; gap: 12px; }
.point-exchange-item { display: flex; justify-content: space-between; align-items: center; padding: 14px; border-radius: var(--radius-md); background: linear-gradient(135deg, var(--primary-lighter) 0%, var(--accent-light) 100%); border: 1px solid rgba(22, 93, 255, 0.1); }
.point-exchange-desc { font-size: 14px; font-weight: 500; }
.point-exchange-btn { padding: 8px 16px; background: var(--primary); color: white; border: none; border-radius: var(--radius-md); font-size: 13px; cursor: pointer; font-weight: 600; transition: var(--transition); white-space: nowrap; }
.point-exchange-btn:active { transform: scale(0.95); }

.guide-card { background: var(--card); border-radius: var(--radius-xl); padding: var(--space-2xl); margin-bottom: var(--space-lg); border: 1px solid var(--border); transition: var(--transition); }
.guide-card:active { border-color: var(--primary); }
.guide-header { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.guide-avatar { width: 40px; height: 40px; background: linear-gradient(135deg, var(--primary) 0%, var(--primary-gradient-end) 100%); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: white; font-weight: 600; }
.guide-author { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.guide-time { font-size: 12px; color: var(--text-tertiary); }
.guide-title { font-size: 16px; font-weight: 600; color: var(--text-primary); margin-bottom: 8px; line-height: 1.4; }
.guide-content { font-size: 14px; color: var(--text-secondary); line-height: 1.6; }
.guide-footer { display: flex; gap: 16px; margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--border-light); }
.guide-action { display: flex; align-items: center; gap: 4px; font-size: 13px; color: var(--text-secondary); cursor: pointer; }
.guide-action:active { color: var(--primary); }

.toast { position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); background: var(--text-primary); color: white; padding: 14px 24px; border-radius: var(--radius-md); font-size: 14px; font-weight: 500; z-index: 10001; opacity: 0; visibility: hidden; transition: var(--transition); max-width: 80%; text-align: center; pointer-events: none; }
.toast.show { opacity: 1; visibility: visible; }

.spinner { width: 40px; height: 40px; border: 3px solid var(--border); border-top-color: var(--primary); border-radius: 50%; animation: spin 1s linear infinite; margin: var(--space-2xl) auto; }
@keyframes spin { to { transform: rotate(360deg); } }

.policy-container { background: var(--card); border-radius: var(--radius-xl); padding: var(--space-2xl); box-shadow: var(--shadow-sm); }
.policy-title { color: var(--primary); font-size: 24px; margin-bottom: var(--space-2xl); text-align: center; font-weight: 800; }
.policy-section { margin-bottom: var(--space-2xl); }
.policy-section h2 { color: var(--text-primary); font-size: 16px; margin: var(--space-2xl) 0 12px; font-weight: 700; }
.policy-section p { color: var(--text-secondary); line-height: 1.8; margin-bottom: 12px; font-size: 14px; }
.policy-highlight { background: var(--warning-light); border-radius: var(--radius-md); padding: 16px; margin: var(--space-2xl) 0; border-left: 4px solid var(--warning); }

/* 用户服务协议 / 隐私政策：长文排版（语义 HTML） */
.policy-section.policy-doc { margin-top: 0; }
.policy-section.policy-doc > .policy-meta { text-align: center; color: var(--text-tertiary); font-size: 14px; margin: -12px 0 28px; line-height: 1.6; }
.policy-section.policy-doc h1 { font-size: 22px; margin-bottom: 24px; text-align: center; font-weight: 800; color: var(--primary); }
.policy-section.policy-doc h2 { font-size: 19px; margin-top: 36px; padding-bottom: 12px; border-bottom: 1px solid var(--border-light); font-weight: 700; color: var(--text-primary); }
.policy-section.policy-doc h3 { font-size: 16px; margin-top: 24px; color: var(--text-primary); font-weight: 600; }
.policy-section.policy-doc > p,
.policy-section.policy-doc p { font-size: 15px; line-height: 1.8; color: var(--text-secondary); margin-bottom: 14px; }
.policy-container.policy-doc > .policy-section { margin-bottom: 24px; }
.policy-container.policy-doc > .policy-section:last-child { margin-bottom: 0; }
.policy-section.policy-doc h2:first-of-type { margin-top: 12px; }
.policy-section.policy-doc p + h2,
.policy-section.policy-doc ul + h2,
.policy-section.policy-doc ol + h2 { margin-top: 36px; }
.policy-section.policy-doc ul,
.policy-section.policy-doc ol { margin: 0 0 16px 1.5em; padding: 0; }
.policy-section.policy-doc li { margin-bottom: 10px; font-size: 15px; line-height: 1.7; color: var(--text-secondary); }
.policy-section.policy-doc ol { padding-left: 0.4em; }
.policy-section.policy-doc .policy-subline { padding-left: 1.5em; color: var(--text-secondary); margin-top: -4px; }
.policy-section.policy-doc table.policy-table { width: 100%; border-collapse: collapse; font-size: 14px; margin: 16px 0 24px; }
.policy-section.policy-doc table.policy-table th,
.policy-section.policy-doc table.policy-table td { border: 1px solid var(--border-light); padding: 12px 14px; vertical-align: top; text-align: left; }
.policy-section.policy-doc table.policy-table th { background: var(--bg-secondary); color: var(--text-primary); font-weight: 600; }

/* 表格外层滚动容器 */
.policy-section.policy-doc .policy-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; margin: 16px 0 24px; }
.policy-section.policy-doc .policy-table-wrap table.policy-table { margin: 0; }

/* 移动端卡片布局 - 默认隐藏 */
.policy-section.policy-doc .policy-table-cards { display: none; }

@media (max-width: 767px) {
  /* 移动端隐藏传统表格，显示卡片 */
  .policy-section.policy-doc .policy-table-wrap { display: none; }
  .policy-section.policy-doc .policy-table-cards { display: block; margin: 16px 0 24px; }
  .policy-section.policy-doc .policy-table-card {
    background: var(--bg-secondary, #f8f9fa);
    border: 1px solid var(--border-light, #e0e0e0);
    border-radius: 8px;
    padding: 14px 16px;
    margin-bottom: 12px;
  }
  .policy-section.policy-doc .policy-table-card-row {
    display: flex;
    flex-direction: column;
    padding: 6px 0;
    border-bottom: 1px solid var(--border-light, #eee);
  }
  .policy-section.policy-doc .policy-table-card-row:last-child { border-bottom: none; }
  .policy-section.policy-doc .policy-table-card-label {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-secondary, #666);
    margin-bottom: 4px;
  }
  .policy-section.policy-doc .policy-table-card-value {
    font-size: 14px;
    color: var(--text-primary, #333);
    line-height: 1.5;
  }
}

.policy-section.policy-doc strong { color: var(--text-primary); font-weight: 600; }

@media (min-width: 768px) {
  .bottom-nav { 
    max-width: 600px; 
    left: 50%; 
    transform: translateX(-50%); 
    border-radius: var(--radius-xl) var(--radius-xl) 0 0; 
    border-left: 1px solid var(--border-light); 
    border-right: 1px solid var(--border-light);
    box-shadow: 0 -4px 24px rgba(0, 0, 0, 0.1);
  }
  
  .publish-fab { 
    right: calc(50% - 280px); 
  }
}

@media (max-width: 375px) {
  .category-grid { grid-template-columns: repeat(4, 1fr); gap: 8px; }
  .category-icon { width: 36px; height: 36px; font-size: 16px; }
  .category-name { font-size: var(--font-size-xs); }
  
  /* 移动端紧凑布局优化 */
  .content-card {
    padding: var(--space-md);
    margin-bottom: var(--space-md);
  }
  
  .card-header {
    margin-bottom: var(--space-sm);
  }
  
  .card-title {
    font-size: 16px;
  }
  
  .card-price {
    font-size: 18px;
  }
  
  .card-images {
    gap: 6px;
    margin: 10px 0;
  }
  
  .card-desc {
    font-size: 13px;
    line-height: 1.5;
    margin-bottom: 10px;
  }
  
  .contact-section {
    margin-top: 10px;
  }
  
  .share-section {
    margin-top: 12px;
    padding-top: 10px;
  }
  
  .card-footer {
    padding-top: 10px;
    margin-top: 10px;
  }
}

#homePage .header-content--home .header-right--home {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

#homePage .header-content--home .header-left {
  flex: 1 1 auto;
  min-width: 0;
}

#homePage .header-content--home .header-trailing--home {
  margin-left: 6px;
}

#homePage .header-content--home .region-btn {
  height: 32px;
  max-width: 140px;
  padding: 0 8px;
}

#homePage .header-content--home .city-btn {
  height: 32px;
  min-width: 104px;
  max-width: 136px;
  padding: 0 8px;
}

@media (max-width: 768px) {
  /* 首页顶栏一行：Logo → 国家 → 地区 → 语言（右） */
  #homePage .header-content--home {
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
    gap: 6px;
    width: 100%;
    min-width: 0;
  }
  /* display:contents 展平后，按钮本身参与顶栏 flex，需统一垂直对齐 */
  #homePage .header-content--home .region-btn,
  #homePage .header-content--home .city-btn {
    align-self: center;
    margin-top: 0;
    margin-bottom: 0;
  }
  #homePage .header-content--home .header-left {
    display: flex;
    flex: 1 1 auto;
    align-items: center;
    min-width: 0;
    margin-right: 0;
  }
  #homePage .header-content--home .logo {
    gap: 6px;
  }
  #homePage .header-content--home .logo-icon {
    width: 28px;
    height: 28px;
    font-size: 14px;
  }
  #homePage .header-content--home .logo-text {
    font-size: 15px;
  }
  #homePage .header-content--home .header-right--home {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-left: auto;
    flex: 0 0 auto;
  }
  #homePage .header-content--home .region-selector {
    flex: 0 0 auto;
    min-width: 0;
  }
  #homePage .header-content--home .city-selector {
    flex: 0 0 auto;
    min-width: 0;
  }
  #homePage .header-content--home .header-trailing--home {
    flex: 0 0 auto;
    margin-left: 6px;
  }
  #homePage .header-content--home .region-btn {
    width: auto;
    min-width: 0;
    max-width: min(112px, 30vw);
    height: 32px;
    padding: 0 6px;
  }
  #homePage .header-content--home .city-btn {
    width: auto;
    min-width: 0;
    max-width: min(102px, 28vw);
    height: 32px;
    padding: 0 6px;
  }
  #homePage .header-content--home .region-btn .region-name,
  #homePage .header-content--home .city-btn .city-btn-label {
    max-width: min(56px, 18vw);
    font-size: 11px;
    font-weight: 500;
    line-height: 1.2;
  }
  #homePage .header-content--home .lang-btn {
    padding: 0 12px;
    font-size: 12px;
  }
  #guidePage.gcv2-page > .gcv2-top-bar {
    gap: 4px;
  }
  #guidePage.gcv2-page .gcv2-country-btn {
    width: auto;
    min-width: 0;
    max-width: min(112px, 30vw);
    height: 32px;
    padding: 0 6px;
  }
  #guidePage.gcv2-page .gcv2-city-btn {
    width: auto;
    min-width: 0;
    max-width: min(102px, 28vw);
    height: 32px;
    padding: 0 6px;
  }
  #guidePage.gcv2-page .gcv2-country-name,
  #guidePage.gcv2-page .gcv2-city-btn .city-btn-label {
    max-width: min(56px, 18vw);
    font-size: 11px;
    line-height: 1.2;
  }
  /* 选国家：相对国家按钮水平居中（不用 fixed，避免 header 上 backdrop-filter/will-change 把 fixed 绑在顶栏内导致点不到） */
  #homePage .header {
    overflow: visible;
  }
  #homePage .header .container {
    overflow: visible;
  }
  #homePage .region-selector {
    position: relative;
    z-index: 5;
  }
  #homePage .region-selector .region-dropdown {
    position: absolute;
    left: 0;
    right: auto;
    top: calc(100% + 6px);
    transform: none;
    width: auto;
    min-width: 180px;
    max-width: min(220px, calc(100vw - 28px));
    max-height: min(48vh, 320px);
    z-index: 5000;
    box-shadow: var(--shadow-lg);
  }
  #homePage .region-selector .region-dropdown.show {
    animation: regionDropdownHomeIn 0.2s ease;
  }
  .home-search-ai-row { gap: 12px; }
  .vip-swiper {
    height: 200px;
  }

  .guide-comment-composer-footer {
    flex-direction: column;
    align-items: stretch;
  }
}

@media (max-width: 380px) {
  #homePage .header-content--home {
    gap: 4px;
  }
  #homePage .header-content--home .logo-icon {
    width: 26px;
    height: 26px;
    font-size: 13px;
  }
  #homePage .header-content--home .logo-text {
    font-size: 14px;
  }
  #homePage .header-content--home .region-btn {
    height: 30px;
    padding: 0 6px;
    max-width: min(102px, 28vw);
  }
  #homePage .header-content--home .city-btn {
    height: 30px;
    padding: 0 6px;
    max-width: min(92px, 26vw);
  }
  #homePage .header-content--home .region-btn .region-name,
  #homePage .header-content--home .city-btn .city-btn-label {
    max-width: min(46px, 16vw);
    font-size: 10px;
    font-weight: 500;
    line-height: 1.2;
  }
  #homePage .header-content--home .lang-btn {
    padding: 0 8px;
    font-size: 11px;
  }
  #guidePage.gcv2-page .gcv2-country-btn {
    height: 30px;
    padding: 0 6px;
    max-width: min(102px, 28vw);
  }
  #guidePage.gcv2-page .gcv2-city-btn {
    height: 30px;
    padding: 0 6px;
    max-width: min(92px, 26vw);
  }
  #guidePage.gcv2-page .gcv2-country-name,
  #guidePage.gcv2-page .gcv2-city-btn .city-btn-label {
    max-width: min(46px, 16vw);
    font-size: 10px;
    line-height: 1.2;
  }
}

@media (max-width: 320px) {
  .category-grid { grid-template-columns: repeat(3, 1fr); gap: 6px; }
  .category-icon { width: 32px; height: 32px; font-size: 14px; }
  .category-name { font-size: var(--font-size-xs); }
  .card-images { grid-template-columns: repeat(2, 1fr); }
  .container { padding: 0 var(--space-md); }
  
  /* 超小屏幕导航优化 */
  .nav-item {
    min-width: 56px;
    padding: 4px 6px;
  }
  
  .nav-icon {
    font-size: 20px;
  }
  
  .nav-label {
    font-size: var(--font-size-xs);
  }
  
  .publish-fab {
    width: 52px;
    height: 52px;
    font-size: 28px;
    right: 16px;
    bottom: calc(78px + var(--safe-bottom));
  }
  .vip-swiper {
    height: 184px;
  }
}

@supports (-webkit-touch-callout: none) {
  .header { padding-top: calc(var(--space-lg) + var(--safe-top)); }
}

body.tg-webapp {
  --bg-primary: var(--tg-theme-bg-color, var(--bg-primary));
  --text-primary: var(--tg-theme-text-color, var(--text-primary));
  --button-color: var(--tg-theme-button-color, var(--primary));
  --button-text-color: var(--tg-theme-button-text-color, white);
}

@media print {
  .header, .bottom-nav, .publish-fab, .modal-overlay { display: none !important; }
  body { padding-bottom: 0; }
}

/* 横屏模式优化 */
@media (max-height: 500px) and (orientation: landscape) {
  .header { padding: var(--space-sm) 0; }
  .logo-icon { width: 32px; height: 32px; font-size: 14px; }
  .logo-text { font-size: 16px; }
  .category-grid { grid-template-columns: repeat(7, 1fr); gap: 6px; }
  .category-item { padding: 8px 4px; }
  .category-icon { width: 28px; height: 28px; font-size: 14px; }
  .category-name { font-size: var(--font-size-xs); }
  .ai-banner { padding: var(--space-md); }
  .ai-banner-title { font-size: 14px; }
  .ai-banner-desc { font-size: 12px; margin-bottom: var(--space-sm); }
  .vip-swiper { height: 150px; }
  
  /* 横屏导航优化 */
  .bottom-nav {
    padding: 4px 0 calc(12px + var(--safe-bottom));
  }
  
  .nav-item {
    padding: 4px 6px;
    gap: 2px;
  }
  
  .nav-icon {
    font-size: 20px;
  }
  
  .nav-label {
    font-size: var(--font-size-xs);
  }
  
  .publish-fab {
    width: 48px;
    height: 48px;
    font-size: 26px;
    bottom: calc(70px + var(--safe-bottom));
  }
}

/* Google Play / Android 特殊适配 */
@media screen and (display-mode: standalone) {
  body {
    padding-bottom: calc(80px + env(safe-area-inset-bottom, 0px));
  }
  
  .bottom-nav {
    padding-bottom: calc(20px + env(safe-area-inset-bottom, 0px));
  }
  
  .publish-fab {
    bottom: calc(85px + env(safe-area-inset-bottom, 0px));
  }
}

/* 折叠屏设备适配 */
@media (min-width: 768px) and (max-width: 1024px) {
  .container {
    max-width: 720px;
  }
  
  .category-grid {
    grid-template-columns: repeat(7, 1fr);
  }
}

/* 高DPI屏幕优化 */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
  .logo-icon,
  .category-icon,
  .user-avatar {
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
  }
}

/* ==================== 攻略页面样式 ==================== */
.guide-tip-banner {
  background: var(--primary-lighter);
  padding: var(--space-lg);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-lg);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.guide-tip-icon {
  font-size: 20px;
}

.guide-tip-banner span {
  font-size: 14px;
  color: var(--primary);
  font-weight: 500;
}

.guide-publish-info {
  background: linear-gradient(135deg, var(--primary-lighter) 0%, var(--primary-light) 100%);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  margin-bottom: var(--space-lg);
}

.guide-publish-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--primary-hover);
  margin-bottom: var(--space-md);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.guide-publish-title span:first-child {
  font-size: 20px;
}

.guide-publish-rules {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.guide-rule {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: 14px;
  color: var(--primary-hover);
}

.rule-check {
  font-size: 16px;
}

.guide-publish-btn {
  margin-bottom: var(--space-xl);
  padding: var(--space-lg);
  font-size: 16px;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
}

.guide-publish-btn span:first-child {
  font-size: 20px;
}

.guide-toolbar {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.guide-search-wrap {
  width: 100%;
}

.guide-search-input {
  width: 100%;
}

.guide-filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs);
}

.guide-filter-btn {
  border: 1px solid var(--border);
  background: var(--bg-secondary);
  color: var(--text-secondary);
  border-radius: var(--radius-md);
  padding: 6px 12px;
  font-size: 12px;
  cursor: pointer;
  transition: var(--transition);
}

.guide-filter-btn.active {
  border-color: var(--border-focus);
  background: var(--primary-lighter);
  color: var(--primary);
}

.guide-sort-row {
  display: flex;
  gap: var(--space-sm);
  align-items: center;
}

.guide-sort-select {
  flex: 1;
}

/* 攻略内容流 */
.guide-feed {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.guide-post-card {
  background: var(--card);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  box-shadow: var(--shadow-sm);
  transition: var(--transition);
  cursor: pointer;
  border: 1px solid var(--border-light);
}

.guide-post-card:hover {
  box-shadow: var(--shadow-sm);
  background: var(--card-hover);
}

.guide-post-header {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-md);
}

.guide-user-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-gradient-end) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-weight: 600;
  font-size: 18px;
  flex-shrink: 0;
}
.guide-user-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}
img.guide-user-avatar {
  display: block;
  padding: 0;
  object-fit: cover;
}

.guide-user-info {
  flex: 1;
}

.guide-user-name {
  font-size: 15px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 2px;
}

.guide-post-time {
  font-size: 12px;
  color: var(--text-tertiary);
}

.guide-post-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--space-sm);
  line-height: 1.5;
}

.guide-post-content {
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.6;
  margin-bottom: var(--space-md);
}

.guide-post-footer {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px solid var(--border-light);
}

.guide-post-thumb-list {
  display: flex;
  gap: var(--space-sm);
  margin-top: var(--space-sm);
}

.guide-post-thumb {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-md);
  object-fit: cover;
  border: 1px solid var(--border);
}

.guide-modal-tip {
  font-size: 12px;
  color: var(--text-secondary);
  margin-top: 6px;
}

.guide-counter-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 6px;
  font-size: 12px;
  color: var(--text-tertiary);
}

.guide-upload-dropzone {
  border: 1px dashed var(--border);
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
  padding: var(--space-md);
}

.guide-upload-dropzone.dragover {
  border-color: var(--border-focus);
  background: var(--primary-lighter);
}

.guide-upload-actions {
  display: flex;
  gap: var(--space-sm);
  margin-top: var(--space-sm);
}

.guide-upload-list {
  margin-top: var(--space-sm);
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-sm);
}

.guide-upload-item {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: var(--bg-secondary);
  overflow: hidden;
  cursor: pointer;
}

.guide-upload-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.guide-upload-item .mini-btn {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 24px;
  height: 24px;
  border: 1px solid var(--border-light);
  background: rgba(255, 255, 255, 0.92);
  color: var(--text-primary);
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  padding: 0;
  cursor: pointer;
}

.guide-upload-item.is-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-tertiary);
}

.guide-upload-item.is-empty .upload-plus {
  font-size: var(--font-size-2xl);
  line-height: 1;
}

.media-upload-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-sm);
}

.media-upload-cell {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: var(--bg-secondary);
  overflow: hidden;
  cursor: pointer;
}

.media-upload-cell img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.media-upload-cell.is-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-tertiary);
}

.media-upload-cell .upload-plus {
  font-size: var(--font-size-2xl);
  line-height: 1;
}

.media-upload-cell .media-delete-btn {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 24px;
  height: 24px;
  border: 1px solid var(--border-light);
  background: rgba(255, 255, 255, 0.92);
  color: var(--text-primary);
  border-radius: var(--radius-full);
  cursor: pointer;
}

.media-upload-cell .media-cover-badge {
  position: absolute;
  left: 6px;
  bottom: 6px;
  font-size: 10px;
  font-weight: 600;
  color: #fff;
  background: rgba(22, 93, 255, 0.92);
  padding: 2px 8px;
  border-radius: 8px;
  pointer-events: none;
  z-index: 1;
}

.guide-publish-note {
  background: var(--accent-light);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  margin-top: var(--space-md);
}

.guide-post-stat {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: 13px;
  color: var(--text-tertiary);
  cursor: pointer;
  transition: var(--transition);
}

button.guide-post-stat,
button.guide-like-btn {
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font: inherit;
  font-family: inherit;
  color: inherit;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}

.guide-like-btn.is-liked,
.guide-like-btn.is-liked .stat-icon,
.guide-like-btn.is-liked .guide-like-ico {
  color: var(--warning);
}

.guide-post-stat:hover {
  color: var(--primary);
}

.guide-like-btn.is-liked:hover {
  color: #B45309;
}

.guide-post-stat .stat-icon {
  font-size: 16px;
}

.guide-post-stat-comment .stat-icon-comment {
  width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.guide-post-stat-comment .stat-icon-comment svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.guide-detail-modal {
  max-width: 760px;
  max-height: 90vh;
  overflow-y: auto;
}

.guide-detail-modal-body {
  padding-bottom: var(--space-md);
}

/* 攻略详情弹层内复用「信息详情」listing 卡：右侧数据条与主站一致 */
.guide-detail-modal .guide-detail-card-stat.card-price {
  font-size: 15px;
  font-weight: 700;
  color: var(--primary);
  white-space: nowrap;
}

.guide-detail-modal .listing-detail-fav-report {
  flex-wrap: wrap;
  gap: 8px;
}

.guide-detail-modal .listing-detail-fav-report .guide-post-stat {
  margin: 0;
}

/* 攻略详情底部：与广场卡一致 — 收藏·评论·点赞·踩·众裁 */
.guide-detail-modal .listing-detail-fav-report.guide-detail-fav-actions,
#listingDetailPage .listing-detail-fav-report.guide-detail-fav-actions,
#guidePage .gcv2-guide-card .listing-detail-fav-report.guide-detail-fav-actions {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0;
  padding: 10px 0 6px;
  margin-top: 6px;
  border-top: 1px solid var(--border-light);
  font-size: 13px;
  color: #64748b;
}

.guide-detail-modal .guide-detail-fav-actions .guide-card-interact,
#listingDetailPage .guide-detail-fav-actions .guide-card-interact,
#guidePage .gcv2-guide-card .guide-detail-fav-actions .guide-card-interact {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 6px 8px;
  min-height: 36px;
  border: none;
  border-radius: 8px;
  background: transparent;
  color: #64748b;
  cursor: pointer;
  font: inherit;
  line-height: 1;
}

.guide-detail-modal .guide-detail-fav-actions .guide-card-interact:active {
  background: #f1f5f9;
}

.guide-detail-modal .guide-detail-fav-actions .guide-like-btn.is-liked {
  color: #2563eb;
}

.guide-detail-modal .guide-detail-fav-actions .guide-like-btn.is-liked .fa-thumbs-up {
  color: #2563eb;
}

.guide-detail-modal .guide-detail-fav-actions .favorite-btn--icon-only.favorited,
.guide-detail-modal .guide-detail-fav-actions .favorite-btn--icon-only.active {
  color: #ca8a04;
}

.guide-detail-modal .guide-detail-fav-actions .favorite-btn--icon-only.favorited .fa-heart,
.guide-detail-modal .guide-detail-fav-actions .favorite-btn--icon-only.active .fa-heart {
  color: #ca8a04;
}

.guide-detail-modal .guide-detail-fav-actions .guide-downvote-btn.is-down {
  color: #475569;
}

.guide-detail-modal .guide-detail-fav-actions .guide-card-interact-sep {
  color: #cbd5e1;
  font-weight: 600;
  padding: 0 2px;
  user-select: none;
}

.guide-detail-modal .guide-detail-fav-actions .guide-like-count,
.guide-detail-modal .guide-detail-fav-actions #guideDetailCommentCount {
  font-weight: 600;
  font-size: 12px;
  color: #64748b;
}

.guide-detail-modal .guide-detail-fav-actions .guide-card-arb-btn .fa-gavel {
  font-size: 14px;
  opacity: 0.88;
}

.guide-detail-modal .guide-detail-fav-actions .report-btn {
  margin-left: auto;
  flex-shrink: 0;
}

.guide-detail-modal .guide-detail-share-footer {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--border-light);
}
.guide-detail-modal .guide-detail-share-footer .btn {
  font-weight: 600;
}

.guide-detail-arbitrate-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-width: 36px;
  min-height: 36px;
  padding: 6px 8px;
}

.guide-detail-arbitrate-btn .fa-gavel {
  font-size: 14px;
  opacity: 0.88;
  color: #64748b;
}

/* 攻略广场 mini 卡：底部互动单行（移动端加大可点区；竖线分隔） */
:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions).guide-card-interactions {
  display: flex;
  flex-wrap: nowrap;
  align-items: stretch;
  justify-content: flex-start;
  gap: 0;
  margin: 6px 0 8px;
  padding: 4px 0 6px;
  border-top: 1px solid #f1f5f9;
  font-size: 12px;
  color: #64748b;
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  min-height: 36px;
}
:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions).guide-card-interactions::-webkit-scrollbar {
  display: none;
}

:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-card-interact {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  margin: 0;
  padding: 6px 8px;
  min-height: 36px;
  min-width: 36px;
  border: none;
  border-radius: 8px;
  background: transparent;
  color: #64748b;
  cursor: pointer;
  font: inherit;
  line-height: 1;
  transition: background 0.12s ease, color 0.12s ease;
  flex: 0 0 auto;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-card-interact:active {
  background: #f1f5f9;
}

:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-card-interact .fa-heart,
:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-card-interact .fa-comment,
:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-card-interact .fa-thumbs-up,
:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-card-interact .fa-thumbs-down,
:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-card-interact .fa-share-alt {
  font-size: 14px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.1em;
}

:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-like-btn.is-liked {
  color: #2563eb;
}

:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-like-btn.is-liked .fa-thumbs-up {
  color: #2563eb;
}

:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .favorite-btn--icon-only.favorited,
:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .favorite-btn--icon-only.active {
  color: #ca8a04;
}

:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .favorite-btn--icon-only.favorited .fa-heart,
:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .favorite-btn--icon-only.active .fa-heart {
  color: #ca8a04;
}

:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-downvote-btn.is-down {
  color: #475569;
}

:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-card-arb-btn {
  padding: 6px 8px;
}

:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-card-arb-btn .fa-gavel {
  font-size: 14px;
  opacity: 0.88;
}

:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-like-count,
:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-mini-comment-count {
  font-size: 12px;
  font-weight: 600;
  color: #64748b;
  min-width: 1ch;
}

/* 竖线分隔（原「·」文案隐藏，仅作无障碍占位） */
:is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-card-interact-sep {
  display: inline-flex;
  align-self: stretch;
  align-items: center;
  justify-content: center;
  width: 1px;
  min-height: 18px;
  margin: 0 2px;
  padding: 0;
  flex: 0 0 1px;
  flex-shrink: 0;
  background: #e2e8f0;
  color: transparent;
  font-size: 0;
  line-height: 0;
  overflow: hidden;
  user-select: none;
}

@media (max-width: 768px) {
  :is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-card-interact {
    padding: 8px 10px;
    min-height: 40px;
    min-width: 40px;
  }
  :is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-card-interact .fa-heart,
  :is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-card-interact .fa-comment,
  :is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-card-interact .fa-thumbs-up,
  :is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-card-interact .fa-thumbs-down,
  :is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions) .guide-card-interact .fa-share-alt {
    font-size: 16px;
  }
  :is(#guidePage .gcv2-guide-card .guide-detail-fav-actions, #myGuidesCenterList .guide-feed-card-mini .guide-detail-fav-actions, .guide-feed-grid-inner .guide-feed-card-mini .guide-detail-fav-actions).guide-card-interactions {
    min-height: 44px;
    padding-bottom: 8px;
  }
}

#guidePage .gcv2-guide-card .guide-card-interact-spacer {
  flex: 1;
  min-width: 4px;
}

.gcv2-arb-tally-line {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid #e2e8f0;
  font-size: 12px;
}

.gcv2-arbitrate-content .gcv2-arb-tally-line .gcv2-text-muted {
  color: #64748b;
}

.guide-detail-card {
  cursor: default;
}

.guide-comment-section {
  margin-top: var(--space-lg);
  border-top: 1px solid var(--border-light);
  padding-top: var(--space-md);
}

.guide-comment-header h3 {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0;
}

.guide-comment-header-icon {
  font-size: 18px;
  color: var(--primary);
  opacity: 0.9;
}

.guide-comment-auth-tip {
  margin-top: var(--space-sm);
  font-size: 13px;
  color: var(--text-tertiary);
}

.guide-comment-composer {
  margin-top: var(--space-sm);
}

.guide-comment-input {
  min-height: 90px;
}

.guide-comment-composer-footer {
  margin-top: var(--space-xs);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
}

.guide-comment-submit-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.guide-comment-list {
  margin-top: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.guide-comment-item {
  display: flex;
  gap: 12px;
  padding: 12px 12px 10px;
  border: 1px solid var(--border-light);
  border-radius: 12px;
  background: var(--card);
}

.guide-comment-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: linear-gradient(145deg, #f1f5f9 0%, #e2e8f0 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
  border: 1px solid rgba(148, 163, 184, 0.35);
}

.guide-comment-avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.guide-comment-avatar-icon {
  font-size: 28px;
  line-height: 1;
  color: #94a3b8;
}

.guide-comment-avatar-emoji {
  font-size: 20px;
  line-height: 1;
}

.guide-comment-main {
  flex: 1;
  min-width: 0;
}

.guide-comment-top {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 0 6px;
}

.guide-comment-author {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
}

.guide-comment-meta-sep {
  font-size: 12px;
  color: var(--text-tertiary);
  user-select: none;
  line-height: 1;
}

.guide-comment-time {
  font-size: 12px;
  color: var(--text-tertiary);
  font-weight: 500;
}

.guide-comment-content {
  margin-top: 6px;
  font-size: 14px;
  line-height: 1.55;
  color: var(--text-primary);
  word-break: break-word;
}

.guide-comment-actions {
  margin-top: 10px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.guide-comment-act {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 32px;
  padding: 6px 12px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.2;
  border: 1px solid #e2e8f0;
  background: #fff;
  color: #64748b;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
  -webkit-tap-highlight-color: transparent;
}

.guide-comment-act i {
  font-size: 13px;
  opacity: 0.92;
}

.guide-comment-act__label {
  font-weight: 600;
}

.guide-comment-act--delete:hover {
  background: #fef2f2;
  border-color: #fecaca;
  color: #b91c1c;
}

.guide-comment-act--delete:hover i {
  color: #b91c1c;
}

.guide-comment-act--report:hover {
  background: #fffbeb;
  border-color: #fde68a;
  color: #b45309;
}

.guide-comment-act--report:hover i {
  color: #d97706;
}

.guide-comment-empty {
  text-align: center;
  color: var(--text-tertiary);
  font-size: 13px;
  padding: var(--space-md) 0;
}

.my-comment-item {
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
  padding: var(--space-sm);
  margin-bottom: var(--space-sm);
}

.my-comment-guide {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 4px;
}

.my-comment-content {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.5;
}

.my-comment-meta {
  margin-top: 6px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--text-tertiary);
  font-size: 12px;
}

/* ==================== AI工作区样式 ==================== */
.ai-workspace {
  margin-bottom: var(--space-xl);
}

.ai-upload-area {
  background: var(--bg-secondary);
  border: 2px dashed var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-3xl);
  text-align: center;
  cursor: pointer;
  transition: var(--transition);
  margin-bottom: var(--space-lg);
}

.ai-upload-area:hover {
  border-color: var(--primary);
  background: var(--primary-lighter);
}

.ai-upload-area.dragover {
  border-color: var(--primary);
  background: var(--primary-lighter);
  transform: scale(1.01);
}

.upload-icon {
  font-size: 48px;
  margin-bottom: var(--space-md);
}

.upload-text {
  font-size: 15px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--space-sm);
}

.upload-hint {
  font-size: 13px;
  color: var(--text-tertiary);
}

.ai-text-area {
  margin-bottom: var(--space-lg);
}

.ai-text-area .form-textarea {
  resize: vertical;
  min-height: 120px;
  font-family: var(--font-family);
}

.ai-actions {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
}

.ai-actions .btn {
  padding: var(--space-lg);
  font-size: 15px;
  font-weight: 600;
}

.ai-actions .btn-secondary {
  background: #fff;
  color: var(--primary);
  border: 1.5px solid var(--primary);
}

.ai-actions .btn-secondary:hover {
  background: #fff;
  color: var(--primary-hover);
  border-color: var(--primary-hover);
}

/* ===== 首页轻量版（按最新示例） ===== */
#homePage .home-lite-main {
  padding-bottom: 16px;
}
#homePage .search-bar {
  background: #fff;
  border-radius: 40px;
  padding: 8px 10px 8px 18px;
  margin: 0 0 12px;
  border: 1px solid #E2E8F0;
  display: flex;
  align-items: center;
  gap: 6px;
  color: #64748B;
}
#homePage .search-bar .search-input {
  flex: 1;
  min-width: 0;
  padding: 6px 0;
  line-height: 1.35;
}
#homePage .search-bar .search-clear {
  display: none;
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  line-height: 1;
  border-radius: 50%;
}
#homePage .search-bar .search-input:not(:placeholder-shown) ~ .search-clear {
  display: inline-flex;
}
#homePage .home-search-submit {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border: none;
  border-radius: 9999px;
  background: #ECFDF5;
  color: #0D9488;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  transition: background 0.15s ease, transform 0.12s ease;
}
#homePage .home-search-submit:hover {
  background: #CCFBF1;
}
#homePage .home-search-submit:active {
  transform: scale(0.96);
}
#homePage .home-search-submit i {
  font-size: 15px;
  line-height: 1;
  display: block;
}
#homePage .home-search-submit:focus-visible {
  outline: 2px solid #0D9488;
  outline-offset: 2px;
}
#homePage .carousel {
  margin: 0 0 16px;
  border-radius: 20px;
  overflow: hidden;
  height: 140px;
  position: relative;
}
#homePage .carousel-inner { display: flex; width: 500%; height: 100%; animation: slide 25s infinite; }
#homePage .carousel-item { width: 20%; height: 100%; position: relative; }
#homePage .carousel-item img { width: 100%; height: 100%; object-fit: cover; }
#homePage .carousel-caption {
  position: absolute;
  bottom: 12px;
  left: 16px;
  color: #fff;
  font-weight: 700;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
  background: rgba(0, 0, 0, 0.3);
  padding: 4px 12px;
  border-radius: 40px;
  backdrop-filter: blur(4px);
}
@keyframes slide {
  0%,16% { transform: translateX(0); }
  20%,36% { transform: translateX(-20%); }
  40%,56% { transform: translateX(-40%); }
  60%,76% { transform: translateX(-60%); }
  80%,96% { transform: translateX(-80%); }
  100% { transform: translateX(0); }
}
/* 首页 Nordic 布局：隐藏但仍保留分类 chip DOM 供筛选逻辑绑定 */
#homePage .home-nordic-main {
  position: relative;
}
#homePage .home-nordic-sr-tabs {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
#homePage .home-nordic-scrollbar-hide {
  -ms-overflow-style: none;
  scrollbar-width: none;
}
#homePage .home-nordic-scrollbar-hide::-webkit-scrollbar {
  display: none;
}
#homePage .home-nordic-cat-tile:focus-visible,
#homePage .home-nordic-dual-card:focus-visible {
  outline: 2px solid #00c853;
  outline-offset: 2px;
}
#homePage .home-nordic-dual-card,
#homePage .home-nordic-cat-tile,
#homePage #homeNordicDynamicsMount button,
#homePage #homeNordicHotMount button {
  border: 0;
}
#homePage .home-nordic-cat-tile {
  box-shadow: none;
}
#homePage .tab-nav { display: flex; gap: 8px; overflow-x: auto; padding: 0 0 12px; }
#homePage .category-chip {
  background: #F1F5F9;
  padding: 6px 14px;
  border-radius: 40px;
  font-size: 13px;
  white-space: nowrap;
  color: #1E293B;
}
#homePage .category-chip.active { background: var(--primary); color: #fff; }
#homePage .feed-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  padding-bottom: 16px;
  align-items: stretch;
}
#homePage .feed-card-mini {
  background: #fff;
  border-radius: 14px;
  padding: 10px;
  border: none;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.02);
  display: flex;
  flex-direction: column;
  cursor: pointer;
  min-height: 0;
  height: 100%;
}
#homePage .feed-card-mini-main {
  display: flex;
  flex-direction: column;
  min-height: 0;
  min-width: 0;
  flex: 0 1 auto;
}
#homePage .feed-card-mini-head,
#homePage .feed-card-mini-tail {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
#homePage .feed-card-mini--text-only .feed-card-mini-main {
  flex: 1 1 auto;
  justify-content: flex-start;
  gap: 8px;
  min-height: 0;
}
#homePage .feed-card-mini--text-only .feed-card-mini-tail {
  margin-top: 2px;
}
#homePage .feed-card-mini--text-only .card-title-mini {
  font-size: 14px;
  line-height: 1.45;
}
#homePage .feed-card-mini--text-only .card-meta-mini,
#homePage .feed-card-mini--text-only .card-location-mini {
  font-size: 12px;
  line-height: 1.5;
  color: #475569;
}
#homePage .card-badge-mini {
  display: inline-block;
  padding: 2px 6px;
  border-radius: 20px;
  font-size: 9px;
  font-weight: 500;
  margin-bottom: 6px;
  align-self: flex-start;
}
#homePage .badge-hot { background: #FEE2E2; color: #B91C1C; }
#homePage .badge-rental { background: var(--primary-light); color: var(--primary-hover); }
#homePage .badge-job { background: #E0F2FE; color: #0369A1; }
#homePage .badge-vip { background: linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%); color: #fff; }
#homePage .card-title-mini { font-size: 13px; font-weight: 600; color: #1E293B; line-height: 1.35; margin-bottom: 2px; }
#homePage .card-price-mini { font-size: 15px; font-weight: 700; color: var(--primary); margin-bottom: 4px; }
#homePage .card-signal-mini {
  font-size: 10px;
  font-weight: 600;
  color: #B45309;
  margin-bottom: 3px;
}
#homePage .card-heat-mini {
  font-size: 10px;
  color: #64748B;
  margin-bottom: 4px;
}
#homePage .card-meta-mini, #homePage .card-location-mini {
  font-size: 11px;
  line-height: 1.45;
  color: #475569;
  margin-bottom: 2px;
}
#homePage .card-image-mini {
  margin-top: auto;
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: 8px;
  overflow: hidden;
  flex-shrink: 0;
}
#homePage .card-image-mini img { width: 100%; height: 100%; object-fit: cover; display: block; }
#homePage .card-image-mini.is-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #ECFEFF 0%, #F8FAFC 100%);
  border: 1px solid #CFFAFE;
}
#homePage .card-image-mini-dot {
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: rgba(13, 148, 136, 0.22);
}

@media (max-width: 480px) {
  #homePage .feed-card-mini {
    padding: 12px;
  }
  #homePage .feed-card-mini .card-title-mini {
    font-size: 15px;
    line-height: 1.45;
  }
  #homePage .feed-card-mini .card-price-mini {
    font-size: 16px;
  }
  #homePage .feed-card-mini .card-meta-mini,
  #homePage .feed-card-mini .card-location-mini {
    font-size: 12px;
    line-height: 1.5;
    color: #475569;
  }
  #homePage .feed-card-mini .card-badge-mini {
    font-size: 10px;
    padding: 3px 7px;
  }
  #homePage .feed-card-mini .card-signal-mini,
  #homePage .feed-card-mini .card-heat-mini {
    font-size: 11px;
  }
  :is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-mini {
    padding: 12px;
  }
  :is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-mini:not(:has(.guide-card-image-mini)) {
    padding-top: 14px;
    padding-bottom: 16px;
  }
  :is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-mini .guide-card-title-mini {
    font-size: 15px;
    line-height: 1.45;
  }
  :is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-mini .guide-card-meta-mini,
  :is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-mini .guide-card-snippet-mini {
    font-size: 12px;
    line-height: 1.5;
    color: #475569;
  }
  :is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-mini .guide-card-stat-mini {
    font-size: 11px;
  }
  :is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-mini .gcv2-badge {
    font-size: 10px;
    padding: 3px 7px;
  }
}

/* 详情页（三选一解锁） */
#listingDetailPage .listing-detail-main .detail-card {
  background: #fff;
  border-radius: 20px;
  padding: 16px;
  border: 1px solid #E2E8F0;
  margin-bottom: 16px;
}
#listingDetailPage .listing-detail-main .detail-title { font-size: 20px; font-weight: 700; margin-bottom: 6px; }
#listingDetailPage .listing-detail-main .detail-price { font-size: 22px; font-weight: 700; color: var(--primary); margin-bottom: 10px; }
#listingDetailPage .listing-detail-main .detail-meta { font-size: 13px; color: #64748B; margin-bottom: 16px; }
#listingDetailPage .listing-detail-main .detail-desc { font-size: 14px; line-height: 1.5; margin-bottom: 20px; }
#listingDetailPage .listing-detail-main .grid-9 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
  border-radius: 16px;
  overflow: hidden;
  margin-bottom: 16px;
}
#listingDetailPage .listing-detail-main .grid-9 img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; }
#listingDetailPage .listing-detail-main .unlock-options {
  background: #F8FAFC;
  border-radius: 20px;
  padding: 16px;
  border: 1px dashed #CBD5E1;
}
#listingDetailPage .listing-detail-main .unlock-option-card {
  background: #fff;
  border-radius: 16px;
  padding: 16px;
  margin-bottom: 12px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.02);
}
#listingDetailPage .listing-detail-main .option-tag {
  background: var(--primary-light);
  color: var(--primary-hover);
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
}
#listingDetailPage .listing-detail-main .points-large { font-size: 32px; font-weight: 800; color: var(--primary); }

/* 分享/广告浮层 */
.share-sheet, .ad-sheet {
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 100%);
  width: min(480px, calc(100vw - 16px));
  background: #fff;
  border-radius: 24px 24px 0 0;
  padding: 20px 16px 30px;
  box-shadow: 0 -8px 30px rgba(0, 0, 0, 0.05);
  transition: transform 0.25s;
  z-index: 1000;
}
.share-sheet.show, .ad-sheet.show { transform: translate(-50%, 0); }
.sheet-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.2);
  opacity: 0;
  visibility: hidden;
  transition: 0.2s;
  z-index: 999;
}
.sheet-overlay.show { opacity: 1; visibility: visible; }
/* 盖在攻略详情弹层（1100）之上，避免点「分享」后浮层被挡住 */
#shareSheet.share-sheet.show {
  z-index: 1200;
}
.sheet-overlay#shareOverlay.show {
  z-index: 1199;
}
.share-icons { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px 10px; text-align: center; margin: 20px 0; }
.share-icon-item { font-size: 12px; cursor: pointer; color: #1E293B; }
.share-icon-item i { font-size: 32px; display: block; margin-bottom: 6px; color: #0D9488; }
.share-sheet-close-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  min-height: 44px;
  margin: -8px -4px -8px 0;
  padding: 0;
  border: none;
  border-radius: 12px;
  background: transparent;
  color: #64748b;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
}
.share-sheet-close-btn:hover { background: #f1f5f9; color: #0f172a; }
.share-sheet-close-btn:focus-visible { outline: 2px solid var(--primary, #0d9488); outline-offset: 2px; }

/* ==================== Guide Community V2 ==================== */
/* 与主内容区共用横向 gutter，保证顶栏 pill 与下方卡片/搜索左缘对齐 */
#guidePage.gcv2-page {
  --gcv2-gutter-x: 16px;
}
/* 顶栏与 main 共用 .container 同款 max-width，避免浏览器宽屏下与下方内容列错位 */
#guidePage.gcv2-page > .gcv2-top-bar {
  box-sizing: border-box;
  width: 100%;
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: nowrap;
  gap: 6px;
  padding: 8px var(--gcv2-gutter-x);
  min-width: 0;
}
@media (min-width: 768px) {
  #guidePage.gcv2-page > .gcv2-top-bar {
    max-width: 600px;
  }
}
@media (min-width: 1024px) {
  #guidePage.gcv2-page > .gcv2-top-bar {
    max-width: 800px;
  }
}
#guidePage.gcv2-page .gcv2-country-selector,
#guidePage.gcv2-page .gcv2-city-selector,
#guidePage.gcv2-page .gcv2-sync-tip-wrap,
#guidePage.gcv2-page .gcv2-top-actions {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  min-height: 0;
}
#guidePage.gcv2-page .gcv2-country-selector {
  margin-left: auto;
}
#guidePage.gcv2-page .gcv2-sync-tip-wrap {
  margin-left: 0;
}
#guidePage.gcv2-page .gcv2-container {
  padding: 0 var(--gcv2-gutter-x) 16px;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}
.gcv2-country-selector { position: relative; }
.gcv2-city-selector { position: relative; }
.gcv2-country-btn {
  display: inline-grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 6px;
  height: 32px;
  padding: 0 8px;
  min-width: 0;
  max-width: 140px;
  background: var(--primary-light);
  color: var(--primary);
  border: none;
  border-radius: var(--radius-full);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition);
  white-space: nowrap;
}
.gcv2-country-btn:hover {
  background: var(--primary);
  color: #fff;
}
.gcv2-country-btn:active {
  transform: scale(0.96);
}
.gcv2-country-btn:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}
.gcv2-city-btn {
  display: inline-grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 6px;
  height: 32px;
  padding: 0 8px;
  min-width: 104px;
  max-width: 136px;
  background: var(--primary-light);
  color: var(--primary);
  border: none;
  border-radius: var(--radius-full);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition);
  white-space: nowrap;
}
.gcv2-city-btn:hover {
  background: var(--primary);
  color: #fff;
}
.gcv2-city-btn:active {
  transform: scale(0.96);
}
.gcv2-city-btn:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}
.gcv2-country-dropdown {
  display: none;
  position: absolute;
  top: 45px;
  left: 0;
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
  padding: 8px;
  z-index: 100;
  min-width: 180px;
  max-height: 320px;
  overflow: auto;
}
.gcv2-country-dropdown.show { display: block; }
.gcv2-country-item { padding: 8px 16px; cursor: pointer; border-radius: 10px; }
.gcv2-country-item:hover { background: #F8FAFC; }
.gcv2-country-item.active { background: #ECFDF5; color: #0F766E; font-weight: 600; }
.gcv2-country-code {
  font-weight: 700;
  letter-spacing: 0.03em;
  font-size: 12px;
  text-transform: uppercase;
  color: inherit;
  padding: 1px 6px;
  border-radius: 9999px;
  background: rgba(22, 93, 255, 0.12);
}
.gcv2-country-name {
  font-weight: 500;
  font-size: 12px;
  color: inherit;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.gcv2-city-btn .city-btn-label {
  font-weight: 500;
  font-size: 12px;
  color: inherit;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: left;
}
.gcv2-country-btn .arrow,
.gcv2-city-btn .arrow {
  font-size: var(--font-size-xs);
  transition: transform 0.2s;
  opacity: 0.7;
  flex-shrink: 0;
}
.gcv2-country-selector.active .gcv2-country-btn .arrow,
.gcv2-city-selector.active .gcv2-city-btn .arrow {
  transform: rotate(180deg);
}
.gcv2-city-dropdown {
  display: none;
  position: absolute;
  top: 42px;
  left: 0;
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
  padding: 8px;
  z-index: 100;
  min-width: 150px;
  max-height: 320px;
  overflow: auto;
}
.gcv2-city-dropdown.show { display: block; }
.gcv2-city-item {
  width: 100%;
  border: none;
  background: transparent;
  text-align: left;
  padding: 8px 12px;
  border-radius: 8px;
  cursor: pointer;
  color: #334155;
}
.gcv2-city-item:hover { background: #F8FAFC; }
.gcv2-city-item.active { background: #ECFDF5; color: #0F766E; font-weight: 600; }
.gcv2-top-actions { display: flex; gap: 16px; align-items: center; }
.gcv2-sync-tip-wrap { position: relative; display: inline-flex; align-items: center; }
.gcv2-sync-tip-btn {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  border: 1px solid #A7F3D0;
  background: #ECFDF5;
  color: #0F766E;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  cursor: pointer;
}
.gcv2-sync-tip-pop {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  min-width: 160px;
  max-width: 240px;
  background: #ECFDF5;
  border: 1px solid #A7F3D0;
  border-radius: 10px;
  padding: 6px 10px;
  color: #0F766E;
  font-size: 12px;
  line-height: 1.4;
  box-shadow: 0 6px 18px rgba(15, 118, 110, 0.12);
  z-index: 120;
  display: none;
}
.gcv2-sync-tip-pop.show { display: block; }
.gcv2-publish-entry {
  background: none;
  border: none;
  font-size: 15px;
  color: #0D9488;
}
/* 攻略双入口：两卡始终各占一半宽度（勿用 3 列栅格——当前仅 2 个入口，否则会空出一列） */
.gcv2-entry-row {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: stretch;
  gap: 8px;
  margin: 4px 0 8px;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

.gcv2-entry-row .gcv2-dual-card:nth-child(3) {
  flex: 1 1 100%;
  min-width: 0;
}

.gcv2-entry-row > .gcv2-dual-card {
  flex: 1 1 0;
  min-width: 0;
  width: auto;
}

.gcv2-dual-card {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
  min-height: 72px;
  padding: 8px 9px;
  border: none;
  border-radius: 14px;
  cursor: pointer;
  font: inherit;
  color: inherit;
  text-align: left;
  max-width: none;
  box-sizing: border-box;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
  -webkit-tap-highlight-color: transparent;
}

.gcv2-dual-card:active {
  transform: scale(0.985);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.05);
}

.gcv2-dual-card--toolbox {
  background: linear-gradient(165deg, #eef2ff 0%, #e8eeff 45%, #dbeafe 100%);
  border: 1px solid rgba(129, 140, 248, 0.28);
}

.gcv2-dual-card--learn {
  background: linear-gradient(165deg, #ecfdf5 0%, #e6fcf4 45%, #d1fae5 100%);
  border: 1px solid rgba(45, 212, 191, 0.32);
}

.gcv2-dual-card--cozy {
  background: linear-gradient(165deg, #fff7ed 0%, #ffedd5 45%, #fed7aa 100%);
  border: 1px solid rgba(251, 146, 60, 0.34);
}

.gcv2-dual-card-main {
  display: flex;
  align-items: flex-start;
  min-width: 0;
  flex: 1;
}

.gcv2-dual-card-copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  min-width: 0;
}

.gcv2-dual-card-title {
  font-size: 14px;
  font-weight: 700;
  color: #1e293b;
  letter-spacing: -0.015em;
  line-height: 1.2;
}

.gcv2-dual-card-desc {
  font-size: 10px;
  line-height: 1.38;
  color: #64748b;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.gcv2-dual-card-arrow {
  flex-shrink: 0;
  align-self: flex-start;
  font-size: 11px;
  color: #94a3b8;
  padding: 3px 1px 0 0;
}

@media (min-width: 1024px) {
  .gcv2-dual-card {
    min-height: 76px;
    padding: 9px 10px;
  }
}

@media (max-width: 480px) {
  .gcv2-dual-card {
    min-height: 68px;
    padding: 7px 8px;
    border-radius: 12px;
  }
  .gcv2-dual-card-title {
    font-size: 13px;
  }
  .gcv2-dual-card-desc {
    font-size: 10px;
    -webkit-line-clamp: 2;
    line-clamp: 2;
  }
}

.gcv2-toolbox-title { font-weight: 600; font-size: 16px; color: #1E293B; }
.gcv2-text-muted { color: #64748B; font-size: 13px; }
.gcv2-search {
  display: flex;
  align-items: center;
  gap: 6px;
  background: #fff;
  border-radius: 40px;
  padding: 8px 10px 8px 18px;
  margin: 0 0 12px;
  border: 1px solid #E2E8F0;
  color: #64748B;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}
.gcv2-search .gcv2-search-input {
  flex: 1;
  min-width: 0;
  font-size: 14px;
  padding: 6px 0;
  line-height: 1.35;
}
.gcv2-search .search-clear {
  display: none;
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  line-height: 1;
  border-radius: 50%;
}
.gcv2-search .gcv2-search-input:not(:placeholder-shown) ~ .search-clear {
  display: inline-flex;
}
#guidePage .gcv2-search-submit {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border: none;
  border-radius: 9999px;
  background: #ecfdf5;
  color: #0d9488;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  transition: background 0.15s ease, transform 0.12s ease;
}
#guidePage .gcv2-search-submit:hover {
  background: #ccfbf1;
}
#guidePage .gcv2-search-submit:active {
  transform: scale(0.96);
}
#guidePage .gcv2-search-submit i {
  font-size: 15px;
  line-height: 1;
  display: block;
}
#guidePage .gcv2-search-submit:focus-visible {
  outline: 2px solid #0d9488;
  outline-offset: 2px;
}
#guidePage #gcv2BigCatScroll.gcv2-guide-feed-tabs {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 0 0 12px;
  scrollbar-width: none;
}
#guidePage .gcv2-guide-feed-tab {
  background: #f1f5f9;
  padding: 6px 14px;
  border-radius: 40px;
  font-size: 13px;
  white-space: nowrap;
  color: #1e293b;
  cursor: pointer;
  flex-shrink: 0;
  border: 1.5px solid transparent;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
#guidePage .gcv2-guide-feed-tab.active {
  background: var(--primary, #0d9488);
  color: #fff;
  border-color: transparent;
}
.gcv2-category-grid .gcv2-big-cat-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 70px;
  cursor: pointer;
  padding: 8px 4px;
  border-radius: 16px;
  border: 1.5px solid transparent;
  transition: all 0.15s;
}
.gcv2-category-grid .gcv2-big-cat-item.active {
  border-color: #0d9488;
  background: #f0fdf4;
}
.gcv2-category-grid .gcv2-big-cat-item i {
  font-size: 28px;
  margin-bottom: 4px;
  font-style: normal;
}
.gcv2-category-grid .gcv2-big-cat-item span {
  font-size: 12px;
  color: #1e293b;
}
.gcv2-guide-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 8px;
  align-items: stretch;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  min-width: 0;
}
.gcv2-guide-card {
  background: #fff;
  border-radius: 20px;
  padding: 12px;
  border: 1px solid #E2E8F0;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.02);
}
/* 攻略广场双列：同一行两卡等高，底部对齐（摘要区可伸展） */
#guidePage .gcv2-guide-grid > .gcv2-guide-card.guide-feed-card-mini {
  height: 100%;
  align-self: stretch;
  min-height: 0;
  min-width: 0;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  /* 封面图在 .guide-card-image-mini 内自行 overflow:hidden；卡片横向 visible 避免窄屏裁切互动条 */
  overflow-x: visible;
}
#guidePage .gcv2-guide-grid > .guide-feed-card-mini > .guide-feed-card-body--with-media {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
  min-width: 0;
}
#guidePage .gcv2-guide-grid .guide-feed-card-body--with-media .guide-card-snippet-mini {
  flex: 1 1 auto;
  min-height: 0;
  /* 约两行摘要占位，与同行另一卡互动区纵向对齐 */
  min-height: 3em;
}
#guidePage .gcv2-guide-grid .guide-feed-card-body--with-media .guide-card-interactions {
  flex-shrink: 0;
  margin-top: auto;
  max-width: 100%;
}
#guidePage .gcv2-guide-grid .guide-feed-card-body--with-media .guide-card-stat-mini {
  flex-shrink: 0;
  margin-top: auto;
}
#guidePage .gcv2-guide-grid .guide-card-image-mini {
  margin-top: auto;
  flex-shrink: 0;
  width: 100%;
  max-width: 100%;
}
#guidePage .gcv2-guide-grid > .guide-feed-card-mini > .guide-feed-card-stack--text-only {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
}
#guidePage .gcv2-guide-grid .guide-feed-card-stack--text-only .guide-feed-card-stack-tail {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
#guidePage .gcv2-guide-grid .guide-feed-card-stack--text-only .guide-card-snippet-mini {
  flex: 1 1 auto;
  min-height: 3em;
}
#guidePage .gcv2-guide-grid .guide-feed-card-stack--text-only .guide-card-interactions {
  margin-top: auto;
  flex-shrink: 0;
}
#guidePage .gcv2-guide-grid .guide-feed-card-stack--text-only .guide-card-stat-mini,
#guidePage .gcv2-guide-grid .guide-feed-card-stack--text-only .guide-feed-card-actions {
  margin-top: auto;
  flex-shrink: 0;
}

/* 我的攻略中心双列：与攻略广场相同的行等高逻辑 */
#myGuidesCenterList > .guide-feed-card-mini {
  height: 100%;
  align-self: stretch;
  min-height: 0;
  display: flex;
  flex-direction: column;
}
#myGuidesCenterList > .guide-feed-card-mini > .guide-feed-card-body--with-media {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
  min-width: 0;
}
#myGuidesCenterList .guide-feed-card-body--with-media .guide-card-snippet-mini {
  flex: 1 1 auto;
  min-height: 0;
}
#myGuidesCenterList .guide-feed-card-body--with-media .guide-card-interactions,
#myGuidesCenterList .guide-feed-card-body--with-media .guide-card-stat-mini {
  flex-shrink: 0;
  margin-top: auto;
}
#myGuidesCenterList .guide-card-image-mini {
  margin-top: 0;
  flex-shrink: 0;
}
#myGuidesCenterList > .guide-feed-card-mini > .guide-feed-card-stack--text-only {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
}
#myGuidesCenterList .guide-feed-card-stack--text-only .guide-feed-card-stack-tail {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
#myGuidesCenterList .guide-feed-card-stack--text-only .guide-card-snippet-mini {
  flex: 1 1 auto;
  min-height: 0;
}
#myGuidesCenterList .guide-feed-card-stack--text-only .guide-card-interactions,
#myGuidesCenterList .guide-feed-card-stack--text-only .guide-card-stat-mini,
#myGuidesCenterList .guide-feed-card-stack--text-only .guide-feed-card-actions {
  margin-top: auto;
  flex-shrink: 0;
}
/* 攻略单封面 mini 卡：广场 / 我的攻略 / 旧版 #guideFeed 共用（对齐首页信息流） */
.guide-feed-grid-inner {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  align-items: stretch;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}
.guide-feed-card-body--with-media {
  min-width: 0;
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-mini {
  display: flex;
  flex-direction: column;
  cursor: pointer;
  border-radius: 14px;
  padding: 10px;
  min-height: 0;
  min-width: 0;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  align-self: stretch;
  transition: transform 0.12s ease, box-shadow 0.12s ease;
  background: #fff;
  border: 1px solid #e2e8f0;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.02);
  overflow-x: visible;
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-mini:not(:has(.guide-card-image-mini)) {
  padding-top: 12px;
  padding-bottom: 14px;
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-stack--text-only {
  flex: 0 1 auto;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: 8px;
  min-height: 0;
  min-width: 0;
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-stack--text-only .guide-feed-card-stack-tail {
  margin-top: 2px;
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-stack-head,
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-stack-tail {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-stack--text-only .guide-card-title-mini {
  font-size: 14px;
  line-height: 1.45;
  -webkit-line-clamp: 4;
  line-clamp: 4;
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-stack--text-only .guide-card-snippet-mini {
  font-size: 12px;
  line-height: 1.5;
  color: #475569;
  -webkit-line-clamp: 8;
  line-clamp: 8;
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-stack--text-only .guide-card-meta-mini {
  font-size: 11px;
  line-height: 1.5;
  color: #64748b;
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-mini:active {
  transform: scale(0.98);
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-mini .guide-feed-card-head {
  margin-bottom: 6px;
  align-items: flex-start;
  gap: 4px;
  flex-wrap: wrap;
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-mini .gcv2-badge {
  font-size: 9px;
  font-weight: 500;
  padding: 2px 6px;
  margin-bottom: 0;
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-card-title-mini {
  font-size: 13px;
  font-weight: 600;
  color: #1e293b;
  line-height: 1.35;
  margin-bottom: 4px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-card-meta-mini,
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-card-snippet-mini {
  font-size: 11px;
  color: #475569;
  margin-bottom: 2px;
  line-height: 1.45;
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-card-snippet-mini {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-card-stat-mini {
  font-size: 10px;
  color: #64748b;
  margin-bottom: 4px;
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-card-image-mini {
  margin-top: auto;
  border-radius: 8px;
  overflow: hidden;
  height: 80px;
  flex-shrink: 0;
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-card-image-mini img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-card-image-mini.is-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #ecfeff 0%, #f8fafc 100%);
  border: 1px solid #cffafe;
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-card-image-mini-dot {
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: rgba(13, 148, 136, 0.22);
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-actions .guide-post-stat {
  margin: 0;
  padding: 4px 8px;
}
:is(#guidePage, #myGuidesCenterList, .guide-feed-grid-inner) .guide-feed-card-actions .action-btn {
  margin: 0;
  font-size: 12px;
  padding: 6px 10px;
}
#guidePage .gcv2-guide-card.guide-feed-card-mini {
  padding: 10px;
  border-radius: 14px;
}
#myGuidesCenterList .guide-feed-card-mini.content-card {
  padding: 10px !important;
  margin-bottom: 0 !important;
}
#myGuidesCenterList .guide-mgc-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 8px;
}
#myGuidesCenterList .guide-mgc-actions .guide-mgc-btn {
  flex: 1 1 auto;
  min-width: 0;
  font-size: 12px !important;
  padding: 8px 10px !important;
}
.gcv2-card-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; }
.gcv2-badge { background: #F1F5F9; padding: 4px 10px; border-radius: 20px; font-size: 12px; color: #1E293B; }
.gcv2-ad-flag { background: #FEF3C7; color: #B45309; padding: 2px 6px; border-radius: 20px; font-size: 10px; font-weight: 500; }

.gcv2-arbiter-pill {
  display: inline-block;
  margin-left: 4px;
  padding: 1px 7px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 600;
  vertical-align: middle;
  background: #0d9488;
  color: #fff;
  letter-spacing: 0.02em;
}
.gcv2-card-title {
  font-size: 15px;
  font-weight: 600;
  color: #1E293B;
  line-height: 1.3;
  margin-bottom: 4px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.gcv2-card-meta { font-size: 11px; color: #64748B; display: flex; align-items: center; gap: 6px; margin-bottom: 6px; }
.gcv2-card-images { display: flex; gap: 4px; overflow-x: auto; margin-bottom: 8px; scrollbar-width: none; }
.gcv2-card-images img { width: 70px; height: 70px; object-fit: cover; border-radius: 10px; border: 1px solid #E2E8F0; }
.gcv2-card-excerpt {
  font-size: 12px;
  color: #475569;
  line-height: 1.4;
  margin-bottom: 8px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.gcv2-card-footer { display: flex; align-items: center; justify-content: space-between; }
.gcv2-card-stats { font-size: 11px; color: #64748B; }
.gcv2-card-actions { display: flex; gap: 10px; }
.gcv2-card-actions span { font-size: 16px; cursor: pointer; color: #64748B; }
.gcv2-card-actions span.active { color: #0D9488; }
.gcv2-adwall-wrap { margin: 16px 0; cursor: pointer; }
.gcv2-adwall-head { background: #FEF3C7; border-radius: 20px; padding: 12px; display: flex; align-items: center; justify-content: space-between; }
.gcv2-adwall-title { display: flex; align-items: center; gap: 6px; color: #1E293B; }
.gcv2-adwall-content { display: none; background: #fff; border-radius: 16px; padding: 12px; margin-top: 8px; }
.gcv2-adwall-content.show { display: block; }

/* Publish guide page */
.gcv2-step-indicator { display: flex; align-items: center; justify-content: center; gap: 8px; margin: 16px 0; }
.gcv2-step-dot { width: 8px; height: 8px; border-radius: 4px; background: #CBD5E1; }
.gcv2-step-dot.active { background: #0D9488; width: 24px; }
.gcv2-section-card {
  background: #fff;
  border-radius: 20px;
  padding: 16px;
  margin-bottom: 12px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.02);
  border: 1px solid #E2E8F0;
}
.gcv2-section-title { font-weight: 600; margin-bottom: 12px; color: #1E293B; }
.gcv2-category-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.gcv2-input {
  width: 100%;
  padding: 12px;
  border-radius: 40px;
  border: 1px solid #E2E8F0;
  margin: 8px 0;
}
.gcv2-textarea {
  width: 100%;
  padding: 12px;
  border-radius: 20px;
  border: 1px solid #E2E8F0;
  margin: 8px 0;
}
.gcv2-ai-actions { display: flex; gap: 8px; }
.gcv2-ai-actions .btn { flex: 1; }
.gcv2-upload-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin: 16px 0; }
.gcv2-upload-item {
  aspect-ratio: 1;
  background: #F8FAFC;
  border-radius: 12px;
  border: 1.5px dashed #CBD5E1;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #64748B;
  cursor: pointer;
  overflow: hidden;
}
.gcv2-upload-item img { width: 100%; height: 100%; object-fit: cover; }
.gcv2-upload-item.cover { border-color: #0D9488; border-style: solid; }
.gcv2-preview-card { background: #fff; border-radius: 20px; padding: 16px; border: 1px solid #E2E8F0; margin-top: 8px; }
.gcv2-preview-title { font-size: 16px; font-weight: 600; margin-bottom: 4px; color: #1E293B; }
.gcv2-preview-meta { display: flex; gap: 12px; color: #64748B; font-size: 12px; margin: 8px 0; }
.gcv2-preview-images { display: flex; gap: 6px; margin: 8px 0; overflow-x: auto; }
.gcv2-preview-images img { width: 70px; height: 70px; object-fit: cover; border-radius: 10px; }

/* Modals + toast */
.gcv2-modal-card { max-width: 340px; text-align: center; padding: 24px; }
.gcv2-modal-text { text-align: left; margin: 16px 0; }

/* 攻略众裁弹窗：天平 +「社区众裁」、主问句、标签化预览、三按钮一行、底部参与统计 */
.gcv2-arbitrate-modal.gcv2-modal-card {
  max-width: 360px;
  padding: 22px 20px 20px;
  border-radius: 24px;
  text-align: center;
  box-shadow: 0 20px 50px rgba(15, 23, 42, 0.18);
}

.gcv2-arbitrate-modal__head {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 6px;
}

.gcv2-arbitrate-modal__icon {
  font-size: 28px;
  color: #0d9488;
  line-height: 1;
}

.gcv2-arbitrate-modal__title {
  font-size: 18px;
  font-weight: 700;
  color: #0f172a;
  letter-spacing: 0.02em;
}

.gcv2-arbitrate-subtitle {
  margin: 0 0 10px;
  padding: 0 6px;
  font-size: 13px;
  line-height: 1.55;
  color: #64748b;
  text-align: center;
}

.gcv2-arbitrate-content {
  background: #f7f8fa;
  border-radius: 16px;
  padding: 14px 16px;
  margin: 12px 0 16px;
  text-align: left;
  border: 1px solid #e8eaed;
}

.gcv2-arbitrate-preview__title {
  font-size: 16px;
  font-weight: 700;
  color: #0f172a;
  line-height: 1.35;
  margin-bottom: 8px;
}

.gcv2-arbitrate-preview__author {
  font-size: 13px;
  font-weight: 600;
  color: #334155;
  margin-bottom: 8px;
}

.gcv2-arbitrate-preview__snippet {
  font-size: 13px;
  color: #64748b;
  line-height: 1.45;
}

.gcv2-arbitrate-preview-block {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.gcv2-arbitrate-labeled {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 6px;
  align-items: baseline;
  font-size: 13px;
  line-height: 1.45;
}

.gcv2-arbitrate-labeled--stack {
  flex-direction: column;
  align-items: flex-start;
}

.gcv2-arbitrate-lbl {
  font-weight: 700;
  color: #334155;
  flex-shrink: 0;
}

.gcv2-arbitrate-val {
  color: #0f172a;
  word-break: break-word;
}

.gcv2-arbitrate-actions--three {
  display: flex;
  flex-direction: row;
  gap: 8px;
  align-items: stretch;
}

.gcv2-arbitrate-actions--three .gcv2-arbitrate-btn {
  flex: 1;
  min-width: 0;
  font-size: 13px;
  padding: 0 6px;
}

.gcv2-arbitrate-stats-line {
  margin: 14px 0 0;
  font-size: 12px;
  line-height: 1.45;
  color: #64748b;
  text-align: center;
}

.gcv2-arbitrate-actions__row {
  display: flex;
  gap: 10px;
  align-items: stretch;
}

.gcv2-arbitrate-btn {
  flex: 1;
  min-height: 46px;
  padding: 0 12px;
  font-size: 15px;
  font-weight: 600;
  border-radius: 22px;
  cursor: pointer;
  border: 2px solid #0d9488;
  transition: background 0.15s ease, color 0.15s ease, opacity 0.15s ease;
}

.gcv2-arbitrate-btn--outline {
  background: #fff;
  color: #0d9488;
}

.gcv2-arbitrate-btn--outline:active {
  opacity: 0.92;
}

.gcv2-arbitrate-btn--solid {
  background: #0d9488;
  color: #fff;
  border-color: #0d9488;
}

.gcv2-arbitrate-btn--solid:active {
  filter: brightness(0.96);
}

.gcv2-arbitrate-btn--full {
  width: 100%;
  flex: none;
}

.gcv2-arbitrate-voted-ui {
  text-align: center;
}

.gcv2-arbitrate-voted-tip {
  margin: 0 0 4px;
  font-size: 14px;
  line-height: 1.5;
  color: #64748b;
}

.gcv2-toast {
  position: fixed;
  bottom: 100px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(0, 0, 0, 0.7);
  color: #fff;
  text-align: center;
  padding: 10px 14px;
  border-radius: 40px;
  font-size: 14px;
  z-index: 2000;
  opacity: 0;
  transition: 0.2s;
}
.gcv2-toast.show { opacity: 1; }
.gcv2-flex-row { display: flex; align-items: center; justify-content: space-between; }
.gcv2-gap-8 { gap: 8px; }
.gcv2-mb-8 { margin-bottom: 8px; }
.gcv2-mt-8 { margin-top: 8px; }
.gcv2-mt-12 { margin-top: 12px; }
.gcv2-mt-16 { margin-top: 16px; }
.is-hidden { display: none !important; }

/* 工具箱 9 宫格 */
.gcv2-tool-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.gcv2-tool-item {
  background: #fff;
  border: 1px solid #E2E8F0;
  border-radius: 16px;
  padding: 12px 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  text-align: center;
  cursor: pointer;
}
.gcv2-tool-item:hover { border-color: #0D9488; }
.gcv2-tool-icon { font-size: 24px; line-height: 1; }
.gcv2-tool-name { font-size: 12px; font-weight: 600; color: #1E293B; }
.gcv2-tool-desc { font-size: 11px; color: #64748B; line-height: 1.25; }

/* 工具详情通用卡片 */
.gcv2-tool-card {
  background: #fff;
  border: 1px solid #E2E8F0;
  border-radius: 20px;
  padding: 14px;
  margin-bottom: 12px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.02);
}
.gcv2-tool-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 10px; }
.gcv2-tool-label { font-size: 13px; color: #64748B; }
.gcv2-tool-value { font-size: 14px; font-weight: 600; color: #1E293B; }
.gcv2-tool-input, .gcv2-tool-select, .gcv2-tool-textarea {
  width: 100%;
  border: 1px solid #E2E8F0;
  border-radius: 12px;
  background: #fff;
  padding: 10px 12px;
  font-size: 13px;
  margin-top: 6px;
}
.gcv2-tool-textarea { border-radius: 14px; min-height: 90px; resize: vertical; }
.gcv2-tool-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 10px; }
.gcv2-tool-note { font-size: 12px; color: #64748B; line-height: 1.4; margin-top: 8px; }
.gcv2-kv-list { display: grid; gap: 6px; }
.gcv2-kv-item { display: flex; justify-content: space-between; font-size: 13px; color: #1E293B; }

/* 工具箱 · 花费记账 */
.gcv2-exp-root { font-size: 14px; color: #1E293B; }
.gcv2-exp-header {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  margin-bottom: 8px;
}
.gcv2-exp-view-toggle {
  font-size: 13px;
  color: #64748B;
  cursor: pointer;
  user-select: none;
}
.gcv2-exp-tab-bar {
  display: flex;
  margin: 8px 0 16px;
  background: #f1f5f9;
  border-radius: 40px;
  padding: 4px;
}
.gcv2-exp-tab {
  flex: 1;
  text-align: center;
  padding: 10px;
  border-radius: 40px;
  font-weight: 500;
  cursor: pointer;
  color: #64748b;
  border: none;
  background: transparent;
  font-size: 13px;
}
.gcv2-exp-tab.active {
  background: #fff;
  color: #0d9488;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}
.gcv2-exp-item {
  padding: 12px 0;
  border-bottom: 1px solid #f1f5f9;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.gcv2-exp-item:last-child { border-bottom: none; }
.gcv2-exp-left { display: flex; align-items: center; gap: 12px; min-width: 0; }
.gcv2-exp-icon {
  width: 40px;
  height: 40px;
  background: #f8fafc;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
}
.gcv2-exp-info { line-height: 1.4; min-width: 0; }
.gcv2-exp-cat { font-size: 12px; color: #64748b; }
.gcv2-exp-amt { font-weight: 600; color: #1e293b; flex-shrink: 0; }
.gcv2-exp-progress {
  height: 6px;
  background: #e2e8f0;
  border-radius: 3px;
  margin: 8px 0 4px;
}
.gcv2-exp-progress-fill {
  height: 6px;
  background: #0d9488;
  border-radius: 3px;
}
.gcv2-exp-trend {
  height: 60px;
  background: linear-gradient(180deg, #0d9488, #ccfbf1);
  border-radius: 12px;
  opacity: 0.35;
  margin-top: 8px;
}
.gcv2-exp-badge {
  background: #f1f5f9;
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 12px;
  color: #1e293b;
}
#gcv2ExpenseModal.modal-overlay.show { z-index: 1100; }
#gcv2ExpenseModal .gcv2-exp-modal-card {
  background: #fff;
  border-radius: 24px;
  padding: 24px;
  width: min(320px, calc(100vw - 32px));
  max-height: 80vh;
  overflow-y: auto;
  box-shadow: var(--shadow-xl, 0 12px 40px rgba(0, 0, 0, 0.12));
}

/* 工具箱：折扣雷达 / 法律避坑 等详情区块 */
.gcv2-tool-chip-row {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 4px 0 8px;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.gcv2-tool-chip-row::-webkit-scrollbar {
  display: none;
}
.gcv2-tool-chip {
  background: #f1f5f9;
  padding: 6px 14px;
  border-radius: 40px;
  font-size: 13px;
  white-space: nowrap;
  cursor: pointer;
  border: none;
  flex-shrink: 0;
  color: #1e293b;
  font-family: inherit;
}
.gcv2-tool-chip.active {
  background: #0d9488;
  color: #fff;
}
.gcv2-tool-guide-card {
  background: #fff;
  border-radius: 20px;
  padding: 16px;
  margin-bottom: 12px;
  border: 1px solid #e2e8f0;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.02);
}
.gcv2-tool-guide-card--warn {
  background: #fef3c7;
}
.gcv2-tool-pill {
  display: inline-flex;
  align-items: center;
  background: #f1f5f9;
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 12px;
  color: #1e293b;
  border: none;
  cursor: pointer;
  font-family: inherit;
}
.gcv2-tool-pill--accent {
  background: #e8f0fe;
  color: #0d9488;
}
.gcv2-tool-pill--hot {
  background: #fff7ed;
  color: #c2410c;
}
.gcv2-tool-pill--amber {
  background: #f59e0b;
  color: #fff;
}
.gcv2-tool-pill--ok {
  background: #ccfbf1;
  color: #0f766e;
}
.gcv2-ml-6 {
  margin-left: 6px;
}

/* 统一发布 sheet（保留 gcv2-sheet-card 类名供结构兼容） */
.gcv2-sheet-card { width: min(360px, calc(100vw - 24px)); border-radius: 20px; padding: 12px; }
.gcv2-sheet-list { display: grid; gap: 8px; margin-top: 6px; }
.gcv2-sheet-item {
  border: 1px solid #E2E8F0;
  background: #fff;
  border-radius: 12px;
  padding: 10px 12px;
  text-align: left;
  font-size: 14px;
  color: #1E293B;
}
.gcv2-sheet-item:hover { border-color: #0D9488; color: #0D9488; }

/* 发布中枢底部抽屉 */
#gcv2PublishSheetOverlay.modal-overlay.show {
  align-items: flex-end;
  justify-content: center;
  padding: 0;
  background: rgba(15, 23, 42, 0.45);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}
.gcv2-sheet-card--enhanced.gcv2-publish-hub-sheet {
  width: min(430px, 100vw);
  max-width: 100%;
  max-height: min(82vh, 100dvh - 12px);
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: 28px 28px 0 0;
  padding: 8px 16px max(16px, calc(12px + env(safe-area-inset-bottom, 0px)));
  margin: 0 auto;
  background: linear-gradient(180deg, #fafbfc 0%, #fff 12%);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(226, 232, 240, 0.95);
  border-bottom: none;
  box-shadow: 0 -12px 40px rgba(15, 23, 42, 0.08);
}
.gcv2-publish-hub-handle {
  width: 40px;
  height: 4px;
  border-radius: 999px;
  background: #cbd5e1;
  margin: 0 auto 12px;
  opacity: 0.85;
}
.gcv2-publish-hub-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
  padding: 0 4px;
}
.gcv2-publish-hub-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  font-size: 18px;
  color: #1e293b;
  letter-spacing: -0.02em;
}
.gcv2-publish-hub-title .fas.fa-robot {
  color: #0d9488;
  font-size: 20px;
}
.gcv2-publish-hub-close {
  border: none;
  background: transparent;
  font-size: 22px;
  line-height: 1;
  color: #94a3b8;
  padding: 8px 10px;
  margin: -8px -6px -8px 0;
  border-radius: 12px;
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease;
}
.gcv2-publish-hub-close:hover {
  background: #f1f5f9;
  color: #64748b;
}
.gcv2-publish-hub-ai-row {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 14px;
  margin: 0 0 16px;
  border: none;
  border-radius: 16px;
  cursor: pointer;
  text-align: left;
  font: inherit;
  background: linear-gradient(135deg, #e8f0fe, #d4e2fc);
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.06);
  transition: box-shadow 0.15s ease, transform 0.12s ease;
}
.gcv2-publish-hub-ai-row:hover {
  box-shadow: 0 4px 16px rgba(22, 93, 255, 0.12);
}
.gcv2-publish-hub-ai-row:active {
  transform: scale(0.99);
}
.gcv2-publish-hub-ai-row-left {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  flex: 1;
}
.gcv2-publish-hub-ai-row-left .fas.fa-robot {
  flex-shrink: 0;
  font-size: 22px;
  color: #0d9488;
}
.gcv2-publish-hub-ai-row-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.gcv2-publish-hub-ai-row-title {
  font-size: 15px;
  font-weight: 700;
  color: #1e293b;
  line-height: 1.25;
}
.gcv2-publish-hub-ai-row-sub {
  font-size: 12px;
  color: #64748b;
  line-height: 1.35;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
}
.gcv2-publish-hub-ai-row-cta {
  flex-shrink: 0;
  font-size: 13px;
  font-weight: 600;
  color: #0d9488;
  white-space: nowrap;
}
.gcv2-publish-hub-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin: 2px 4px 10px;
}
.gcv2-publish-hub-section-head--spaced {
  margin-top: 14px;
}
.gcv2-publish-hub-section-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  font-size: 14px;
  color: #1e293b;
}
.gcv2-publish-hub-section-label::before {
  content: '';
  width: 3px;
  height: 14px;
  border-radius: 2px;
  background: linear-gradient(180deg, #0d9488, #5eead4);
}
.gcv2-publish-hub-section-hint {
  font-size: 11px;
  font-weight: 500;
  color: #94a3b8;
}
.gcv2-publish-hub-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 4px;
}
.gcv2-publish-hub-grid-more {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 6px;
}
.gcv2-publish-hub-tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  background: #fff;
  padding: 12px 6px 10px;
  cursor: pointer;
  font: inherit;
  color: inherit;
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}
.gcv2-publish-hub-tile:hover {
  border-color: rgba(13, 148, 136, 0.35);
  box-shadow: 0 4px 14px rgba(13, 148, 136, 0.1);
}
.gcv2-publish-hub-tile:active {
  transform: scale(0.97);
}
.gcv2-publish-hub-tile--compact {
  padding: 10px 4px 8px;
  border-radius: 14px;
}
.gcv2-publish-hub-tile-icon {
  width: 48px;
  height: 48px;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 8px;
  font-size: 22px;
  color: #0d9488;
  background: linear-gradient(145deg, #f0fdfa, #f8fafc);
  border: 1px solid rgba(226, 232, 240, 0.95);
}
.gcv2-publish-hub-tile--compact .gcv2-publish-hub-tile-icon {
  width: 44px;
  height: 44px;
  font-size: 19px;
  border-radius: 14px;
  background: #f8fafc;
}
.gcv2-publish-hub-tile-label {
  font-size: 13px;
  font-weight: 600;
  color: #1e293b;
  line-height: 1.25;
}
.gcv2-publish-hub-tile-sub {
  margin-top: 4px;
  font-size: 10px;
  color: #64748b;
  line-height: 1.3;
}
.gcv2-publish-hub-divider {
  height: 1px;
  margin: 14px 0 12px;
  background: linear-gradient(90deg, transparent, #e2e8f0 12%, #e2e8f0 88%, transparent);
}

/* AI 快速指令：底部双轨无缝横向滚动（悬停暂停） */
.gcv2-publish-hub-quick-block {
  margin-top: 4px;
  margin-bottom: 2px;
}
.gcv2-publish-hub-quick-marquee {
  overflow: hidden;
  margin: 4px -6px 0;
  padding: 4px 0 2px;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
}
.gcv2-publish-hub-quick-track {
  display: flex;
  width: max-content;
  animation: gcv2PublishHubQuickMarquee 32s linear infinite;
  will-change: transform;
}
@media (hover: hover) {
  .gcv2-publish-hub-quick-marquee:hover .gcv2-publish-hub-quick-track {
    animation-play-state: paused;
  }
}
@media (prefers-reduced-motion: reduce) {
  .gcv2-publish-hub-quick-track {
    animation: none;
  }
}
@keyframes gcv2PublishHubQuickMarquee {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
.gcv2-publish-hub-quick-seg {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
  padding: 0 6px;
  flex-shrink: 0;
}
.gcv2-publish-hub-quick {
  flex: 0 0 auto;
  border: 1px solid #e2e8f0;
  background: #fff;
  border-radius: 999px;
  padding: 9px 14px;
  font-size: 12px;
  font-weight: 600;
  color: #334155;
  cursor: pointer;
  font-family: inherit;
  white-space: nowrap;
  transition: border-color 0.15s ease, background 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}
.gcv2-publish-hub-quick:hover {
  border-color: rgba(13, 148, 136, 0.45);
  background: #f0fdfa;
  color: #0f766e;
  box-shadow: 0 2px 8px rgba(13, 148, 136, 0.12);
}
.gcv2-publish-hub-quick:active {
  transform: scale(0.98);
}

.gcv2-publish-hub-foot {
  text-align: center;
  font-size: 11px;
  color: #94a3b8;
  margin: 12px 0 0;
  padding-top: 6px;
}

/* 工具页增强 */
.gcv2-correction-card {
  background: #fff;
  border: 1px solid #E2E8F0;
  border-radius: 16px;
  padding: 13px 12px;
  margin-bottom: 10px;
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.05);
}
.gcv2-correction-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  font-weight: 700;
  color: #1E293B;
  line-height: 1.35;
  margin-bottom: 8px;
}
.gcv2-correction-title i {
  color: #0f766e;
  font-size: 14px;
}
.gcv2-correction-lines {
  display: grid;
  gap: 6px;
  font-size: 12px;
  color: #334155;
  line-height: 1.5;
}
#gcv2CorrectionVotesPage .gcv2-correction-lines > div {
  display: flex;
  align-items: flex-start;
  gap: 7px;
  padding: 7px 8px;
  border-radius: 10px;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
}
#gcv2CorrectionVotesPage .gcv2-correction-lines > div i {
  margin-top: 2px;
  color: #0f766e;
  font-size: 12px;
}
#gcv2CorrectionVotesPage .gcv2-correction-lines > div a {
  color: #0f766e;
  text-decoration: underline;
  text-underline-offset: 2px;
  word-break: break-all;
}
#gcv2CorrectionVotesPage .gcv2-correction-lines > div:last-child {
  background: #eff6ff;
  border-color: #bfdbfe;
  color: #1e3a8a;
  font-weight: 600;
}
.gcv2-correction-progress {
  margin-top: 10px;
}
.gcv2-correction-progress-track {
  height: 7px;
  border-radius: 999px;
  background: #e2e8f0;
  overflow: hidden;
}
.gcv2-correction-progress-track > span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #0d9488 0%, #14b8a6 100%);
}
.gcv2-correction-progress p {
  margin: 6px 0 0;
  font-size: 11px;
  color: #64748b;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1;
}
.gcv2-correction-vote-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 12px;
}
.gcv2-correction-vote-row .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
#gcv2CorrectionVotesPage .gcv2-correction-vote-row .btn i {
  font-size: 12px;
}
#gcv2CorrectionVotesPage .gcv2-container {
  padding-bottom: calc(16px + env(safe-area-inset-bottom));
}
#gcv2CorrectionVotesPage #gcv2CorrectionVotesMount {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
#gcv2CorrectionVotesPage .gcv2-correction-card {
  margin-bottom: 0;
}
#gcv2CorrectionVotesPage .gcv2-correction-vote-row .btn {
  min-height: 36px;
  border-radius: 10px;
  font-size: 12px;
  font-weight: 700;
}
#gcv2CorrectionVotesPage .gcv2-correction-vote-row .btn-primary {
  box-shadow: 0 6px 12px rgba(13, 148, 136, 0.16);
}
#gcv2CorrectionVotesPage .gcv2-correction-vote-row .btn-secondary {
  border-color: #cbd5e1;
}
#gcv2CorrectionVotesPage .gcv2-correction-overview {
  border-radius: 16px;
  border: 1px solid color-mix(in oklab, var(--primary) 14%, #e2e8f0);
  background: linear-gradient(145deg, #ffffff 0%, color-mix(in oklab, var(--primary) 8%, #ffffff) 100%);
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.06);
}
#gcv2CorrectionVotesPage .gcv2-correction-overview-title {
  font-size: 13px;
  font-weight: 700;
  color: #1e293b;
  margin-bottom: 10px;
}
#gcv2CorrectionVotesPage .gcv2-correction-overview-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
#gcv2CorrectionVotesPage .gcv2-correction-overview-item {
  border-radius: 10px;
  border: 1px solid #e2e8f0;
  background: #fff;
  text-align: center;
  padding: 8px 6px;
}
#gcv2CorrectionVotesPage .gcv2-correction-overview-item span {
  display: block;
  font-size: 11px;
  color: #64748b;
}
#gcv2CorrectionVotesPage .gcv2-correction-overview-item b {
  display: block;
  margin-top: 5px;
  font-size: 16px;
  font-weight: 800;
  color: #0f172a;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1;
}
#gcv2CorrectionVotesPage .gcv2-correction-empty {
  text-align: center;
  border-radius: 16px;
  border: 1px solid #e2e8f0;
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.05);
}
#gcv2CorrectionVotesPage .gcv2-correction-empty-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  margin: 0 auto 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #f0fdfa;
  color: #0f766e;
  font-size: 18px;
}
#gcv2CorrectionVotesPage .gcv2-correction-empty-title {
  margin: 0;
  font-size: 14px;
  color: #1e293b;
  font-weight: 700;
}
#gcv2CorrectionVotesPage .gcv2-correction-empty-sub {
  margin: 6px 0 0;
  font-size: 12px;
  color: #64748b;
}
@media (max-width: 380px) {
  #gcv2CorrectionVotesPage .gcv2-correction-vote-row {
    grid-template-columns: 1fr;
  }
  #gcv2CorrectionVotesPage .gcv2-correction-overview-item b {
    font-size: 14px;
  }
}
.gcv2-publish-hint {
  margin-top: 8px;
  font-size: 12px;
  color: #64748B;
}
.gcv2-tool-inline {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 8px;
}
.gcv2-emergency-script {
  background: #F8FAFC;
  border: 1px solid #E2E8F0;
  border-radius: 12px;
  padding: 10px;
  font-size: 12px;
  color: #1E293B;
  line-height: 1.45;
  white-space: pre-line;
}

.ai-result-area {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  min-height: 150px;
}

.result-title {
  font-size: 15px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--border);
}

.result-content {
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.6;
  white-space: pre-wrap;
  word-wrap: break-word;
}

.result-content:empty::before {
  content: attr(data-placeholder);
  color: var(--text-tertiary);
  font-style: italic;
}

/* ==================== 底部导航最终覆盖（5入口统一高度） ==================== */
body {
  padding-bottom: calc(76px + env(safe-area-inset-bottom, 0px));
}

.bottom-nav {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 100;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  height: calc(64px + env(safe-area-inset-bottom, 0px));
  padding-bottom: env(safe-area-inset-bottom, 0px);
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-top: 1px solid var(--border);
}

.nav-item {
  height: 64px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  border: none;
  background: transparent;
  color: var(--text-secondary);
  cursor: pointer;
  transition: color 0.2s ease, transform 0.12s ease;
  -webkit-tap-highlight-color: transparent;
}

.nav-icon {
  font-size: 20px;
  line-height: 1;
  color: inherit;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.nav-icon-svg {
  width: 22px;
  height: 22px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.65;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.nav-label {
  font-size: 12px;
  line-height: 1;
  color: inherit;
  font-weight: 500;
}

.nav-item.active,
.nav-item[aria-current="page"] {
  color: var(--primary);
}

.nav-item:active {
  transform: scale(0.96);
}

.publish-fab {
  display: none !important;
}

@media (min-width: 768px) {
  .bottom-nav {
    width: min(calc(100% - 32px), 832px);
    max-width: 832px;
    left: 50%;
    transform: translateX(-50%);
    border-left: 1px solid var(--border);
    border-right: 1px solid var(--border);
    border-top-left-radius: 14px;
    border-top-right-radius: 14px;
  }
}

/* ==================== 国际化 Teal UI 最终覆盖 ==================== */

body {
  background: var(--bg-primary);
  color: var(--text-primary);
  padding-bottom: calc(83px + var(--safe-bottom));
}

.header {
  background: rgba(248, 249, 250, 0.9);
  border-bottom: 1px solid var(--border-light);
}

.search-box,
.form-input,
.form-select,
.form-textarea {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 40px;
}

.search-box {
  padding: 12px 18px;
}

.form-input,
.form-select,
.form-textarea {
  padding: 12px 18px;
}

.search-box:focus-within,
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(13, 148, 136, 0.12);
}

.ai-header-sync-pill {
  cursor: default;
  pointer-events: none;
  min-width: 0;
  max-width: 230px;
  padding: 0 10px;
  gap: 4px;
}

.ai-header-sync-pill .flag {
  width: 16px;
  font-size: 14px;
}

.ai-header-sync-text {
  font-size: 12px;
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (max-width: 480px) {
  #aiPage .header-right {
    gap: 6px;
  }
  .ai-header-sync-pill {
    max-width: 164px;
    padding: 0 8px;
    height: 32px;
  }
  .ai-header-sync-text {
    font-size: 11px;
  }
}

.tab-item {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 40px;
  color: var(--text-primary);
}

.tab-item.active {
  background: var(--primary);
  border-color: var(--primary);
  color: var(--text-inverse);
}

.content-card,
.ai-tool-card,
.user-card,
.menu-list,
.empty-state {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 20px;
  box-shadow: var(--shadow-sm);
}

.content-card {
  padding: 16px;
}

.card-price,
.pay-feature-price,
.pay-price,
.stat-value {
  color: var(--primary);
}

.btn {
  border-radius: 40px;
  min-height: 40px;
  padding: 8px 20px;
}

.btn-primary {
  background: var(--primary);
  color: var(--text-inverse);
}

.btn-primary:hover {
  background: var(--primary-hover);
}

.btn-secondary {
  background: #fff;
  color: var(--primary);
  border: 1.5px solid var(--primary);
}

.btn-secondary:hover {
  background: #fff;
  color: var(--primary-hover);
  border-color: var(--primary-hover);
}

.modal-overlay {
  background: rgba(0, 0, 0, 0.2);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.modal-content {
  border-radius: 24px;
  border: 1px solid var(--border);
  box-shadow: 0 -8px 30px rgba(0, 0, 0, 0.05);
}

.bottom-nav {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  height: calc(83px + env(safe-area-inset-bottom, 0px));
  padding: 0 10px env(safe-area-inset-bottom, 0px);
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-top: 1px solid var(--border);
  box-shadow: 0 -6px 18px rgba(15, 23, 42, 0.06);
  overflow: visible;
  will-change: auto;
}

.nav-item {
  height: 68px;
  min-width: 0;
  gap: 4px;
  color: var(--text-tertiary);
  border-radius: 16px;
}

.nav-item.active,
.nav-item[aria-current="page"] {
  color: var(--primary);
}

/* 底栏「AI·发布」：青绿圆 + 白机器人 + 下方主色文案（与产品设计稿一致） */
.bottom-nav .nav-item--publish-hub {
  width: 100%;
  max-width: 88px;
  margin: 0 auto;
  height: auto;
  min-height: 68px;
  padding: 2px 4px 0;
  transform: translateY(-12px);
  background: transparent !important;
  color: #0d9488;
  gap: 5px;
  justify-content: flex-end;
  position: relative;
  z-index: 1;
}
.bottom-nav .nav-item--publish-hub:hover {
  background: transparent !important;
}
.bottom-nav .nav-item--publish-hub::before {
  display: none !important;
}
.bottom-nav .nav-item--publish-hub .nav-publish-hub-circle {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(145deg, #0d9488, #14b8a6);
  color: #fff !important;
  box-shadow: 0 8px 20px rgba(13, 148, 136, 0.35);
  border: 2px solid rgba(255, 255, 255, 0.55);
}
.bottom-nav .nav-item--publish-hub .nav-publish-hub-circle .fas {
  font-size: 26px;
  line-height: 1;
}
.bottom-nav .nav-item--publish-hub .nav-label {
  display: block;
  font-size: 11px;
  font-weight: 600;
  line-height: 1.15;
  color: #0d9488 !important;
  margin: 0;
  padding: 0 2px;
  text-align: center;
  white-space: nowrap;
}
.bottom-nav .nav-item--publish-hub.active .nav-label,
.bottom-nav .nav-item--publish-hub[aria-current='page'] .nav-label {
  color: #0f766e !important;
  font-weight: 700;
}
.bottom-nav .nav-item--publish-hub.active .nav-publish-hub-circle,
.bottom-nav .nav-item--publish-hub[aria-current='page'] .nav-publish-hub-circle {
  box-shadow: 0 8px 22px rgba(13, 148, 136, 0.42);
}

/* About page: 4-column quick entry + expandable version history */
.hub-about-grid-card { padding: 14px; }
.hub-about-entry-grid {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.hub-about-entry {
  min-height: 46px;
  width: 100%;
  border: 1px solid var(--border-light);
  border-radius: 999px;
  background: var(--bg-secondary);
  color: var(--text-primary);
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  padding: 0 14px;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.2;
  text-align: left;
  cursor: pointer;
  transition: var(--transition);
}
.hub-about-entry i {
  font-size: 15px;
  color: var(--primary);
  width: 18px;
  text-align: center;
  flex-shrink: 0;
}
.hub-about-entry span { flex: 1; min-width: 0; }
.hub-about-entry::after {
  content: '\203A';
  color: var(--text-tertiary);
  font-size: 18px;
  line-height: 1;
  margin-left: 8px;
}
.hub-about-entry:hover { border-color: var(--primary-light); background: #fff; }
.hub-about-entry:active { transform: scale(0.995); }
.hub-about-entry--wide { grid-column: auto; }

.hub-about-version-card { padding: 10px 12px; }
.hub-about-version-details { margin: 0; }
.hub-about-version-summary {
  list-style: none;
  font-weight: 700;
  color: var(--text-primary);
}
.hub-about-version-summary::-webkit-details-marker { display: none; }
.hub-about-version-main { display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 0; }
.hub-about-version-title { font-size: 13px; font-weight: 700; color: var(--text-primary); }
.hub-about-version-hint { font-size: 12px; font-weight: 500; color: var(--text-secondary); }
.hub-about-version-list { margin-top: 10px; border-top: 1px solid var(--border-light); padding-top: 10px; }
.hub-about-version-row { margin: 0 0 8px; font-size: 13px; color: var(--text-primary); }
.hub-about-version-todo { margin: 4px 0 10px; font-size: 12px; color: var(--text-secondary); }

/* ==================== 国际化 Teal UI 二次收敛 ==================== */
.tag.hot {
  background: var(--warning-light);
  color: #B45309;
}

.category-icon,
.category-icon.house,
.category-icon.job,
.category-icon.secondhand,
.category-icon.service,
.category-icon.guide,
.category-icon.daigou,
.category-icon.ai {
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-gradient-end) 100%);
}

.ai-banner {
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-gradient-end) 100%);
  border-radius: 20px;
}

.ai-banner-btn {
  color: var(--primary);
}

.card-images img,
.card-images img::before {
  background: var(--bg-secondary);
}

.ai-actions .btn-secondary {
  background: #fff;
  color: var(--primary);
  border: 1.5px solid var(--primary);
}

.ai-actions .btn-secondary:hover {
  background: #fff;
  color: var(--primary-hover);
  border-color: var(--primary-hover);
}

/* ==================== 学习中文专区（#learnChineseHubPage） ==================== */
#learnChineseHubPage .lch-hub-main {
  padding-bottom: calc(96px + env(safe-area-inset-bottom, 0px));
}

#learnChineseHubPage .lch-view {
  display: none;
}

#learnChineseHubPage .lch-view.active {
  display: block;
}

#learnChineseHubPage .lch-hidden {
  display: none !important;
}

#learnChineseHubPage .lch-module-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 12px 0 16px;
}

#learnChineseHubPage .lch-module-card {
  background: var(--card, #fff);
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 20px;
  padding: 16px 10px;
  text-align: center;
  cursor: pointer;
  font: inherit;
  color: inherit;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.02);
  transition: transform 0.15s ease, background 0.15s ease;
}

#learnChineseHubPage .lch-module-card:active {
  transform: scale(0.98);
  background: var(--bg-secondary, #f8fafc);
}

#learnChineseHubPage .lch-module-icon {
  font-size: 36px;
  display: block;
  margin-bottom: 8px;
}

#learnChineseHubPage .lch-module-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--text-primary, #1e293b);
  display: block;
  margin-bottom: 4px;
}

#learnChineseHubPage .lch-module-sub {
  font-size: 12px;
  color: var(--text-secondary, #64748b);
  display: block;
  margin-bottom: 6px;
}

#learnChineseHubPage .lch-module-tags {
  font-size: 11px;
  color: var(--text-tertiary, #94a3b8);
  display: block;
  line-height: 1.35;
}

#learnChineseHubPage .lch-section-card {
  background: var(--card, #fff);
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 18px;
  padding: 14px 16px;
  margin-bottom: 12px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.02);
}

#learnChineseHubPage .lch-section-card--challenge {
  background: #f0fdf4;
  border-color: var(--primary, #0d9488);
}

#learnChineseHubPage .lch-flex-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

#learnChineseHubPage .lch-text-muted {
  font-size: 13px;
  color: var(--text-secondary, #64748b);
}

#learnChineseHubPage .lch-badge {
  display: inline-block;
  background: #f1f5f9;
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 12px;
  color: #1e293b;
}

#learnChineseHubPage .lch-badge-ai {
  background: #e8f0fe;
  color: var(--primary, #0d9488);
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 12px;
}

#learnChineseHubPage .lch-badge--inverse {
  background: var(--primary, #0d9488);
  color: #fff;
}

#learnChineseHubPage .lch-challenge-title {
  margin: 8px 0;
  font-weight: 600;
  color: var(--text-primary, #1e293b);
}

#learnChineseHubPage .lch-challenge-actions {
  display: flex;
  gap: 8px;
  margin-top: 12px;
}

#learnChineseHubPage .lch-challenge-actions .btn {
  flex: 1;
}

#learnChineseHubPage .lch-link-all {
  border: none;
  background: none;
  padding: 4px 0;
  font: inherit;
  font-size: 14px;
  font-weight: 600;
  color: var(--primary, #0d9488);
  cursor: pointer;
}

#learnChineseHubPage .lch-share-card {
  width: 100%;
  border: none;
  text-align: left;
  cursor: pointer;
  font: inherit;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  background: linear-gradient(135deg, #e8f0fe 0%, #d4e2fc 100%);
  border-radius: 18px;
  padding: 14px 16px;
  margin: 16px 0;
  color: inherit;
}

#learnChineseHubPage .lch-foot-note {
  text-align: center;
  padding: 12px 8px 4px;
  font-size: 12px;
  color: #94a3b8;
}

#learnChineseHubPage .lch-sub-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 0 4px;
}

#learnChineseHubPage .lch-sub-header--split {
  justify-content: space-between;
}

#learnChineseHubPage .lch-sub-header-left {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

#learnChineseHubPage .lch-mock-link {
  border: none;
  background: none;
  font: inherit;
  font-size: 14px;
  font-weight: 600;
  color: var(--primary, #0d9488);
  cursor: pointer;
  flex-shrink: 0;
}

#learnChineseHubPage .lch-filter-bar {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 8px 0 12px;
  scrollbar-width: none;
}

#learnChineseHubPage .lch-filter-bar::-webkit-scrollbar {
  display: none;
}

#learnChineseHubPage .lch-category-chip {
  flex-shrink: 0;
  background: #f1f5f9;
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 13px;
  cursor: pointer;
  user-select: none;
}

#learnChineseHubPage .lch-category-chip.active {
  background: var(--primary, #0d9488);
  color: #fff;
}

#learnChineseHubPage .lch-guide-card {
  background: var(--card, #fff);
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 18px;
  padding: 14px 16px;
  margin-bottom: 12px;
}

#learnChineseHubPage .lch-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
}

#learnChineseHubPage .lch-card-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary, #1e293b);
  margin-bottom: 8px;
}

#learnChineseHubPage .lch-card-title--hanzi {
  font-size: 44px;
  text-align: center;
  margin-bottom: 4px;
}

#learnChineseHubPage .lch-card-pinyin {
  font-size: 13px;
  color: var(--primary, #0d9488);
  margin: 4px 0;
}

#learnChineseHubPage .lch-card-pinyin--center {
  text-align: center;
}

#learnChineseHubPage .lch-card-content {
  font-size: 14px;
  line-height: 1.5;
  color: var(--text-primary, #1e293b);
}

#learnChineseHubPage .lch-card-content--center {
  text-align: center;
}

#learnChineseHubPage .lch-hanzi-visual {
  font-size: 22px;
}

#learnChineseHubPage .lch-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 12px;
  gap: 8px;
}

#learnChineseHubPage .lch-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  font-size: 14px;
  color: var(--text-secondary, #64748b);
}

#learnChineseHubPage .lch-card-actions span {
  cursor: pointer;
}

#learnChineseHubPage .lch-progress-bar {
  height: 6px;
  background: #e2e8f0;
  border-radius: 3px;
  margin-top: 8px;
  overflow: hidden;
}

#learnChineseHubPage .lch-progress-fill {
  height: 6px;
  width: 0;
  background: var(--primary, #0d9488);
  border-radius: 3px;
  transition: width 0.2s ease;
}

#learnChineseHubPage .lch-option-item {
  padding: 12px;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  margin: 8px 0;
  cursor: pointer;
}

#learnChineseHubPage .lch-option-item.selected {
  border-color: var(--primary, #0d9488);
  background: #f0fdf4;
}

#learnChineseHubPage .lch-quiz-result {
  margin-top: 12px;
  font-size: 14px;
  line-height: 1.45;
}

#learnChineseHubPage .lch-exam-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 10px;
  font-size: 13px;
  color: var(--text-secondary, #64748b);
}

#learnChineseHubPage .lch-exam-timer--warn {
  color: #dc2626;
  font-weight: 700;
}

#learnChineseHubPage .lch-mock-actions {
  display: flex;
  gap: 8px;
  margin-top: 12px;
}

#learnChineseHubPage .lch-mock-actions .btn {
  flex: 1;
}

#learnChineseHubPage .lch-mock-h3 {
  font-size: 16px;
  margin: 0 0 6px;
}

#learnChineseHubPage .lch-mock-block {
  margin-bottom: 14px;
}

#learnChineseHubPage .lch-mock-qhead {
  font-weight: 600;
  margin-bottom: 8px;
  font-size: 14px;
}

#learnChineseHubPage .lch-leaderboard-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 0;
  border-bottom: 1px solid var(--border-light, #e2e8f0);
  font-size: 14px;
}

#learnChineseHubPage .lch-leaderboard-item:last-child {
  border-bottom: none;
}

#learnChineseHubPage .lch-rank-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 12px;
  background: #f1f5f9;
  font-size: 12px;
  margin-right: 8px;
}

#learnChineseHubPage .lch-rank-badge.top1 {
  background: #fde68a;
}

#learnChineseHubPage .lch-rank-badge.top2 {
  background: #e5e7eb;
}

#learnChineseHubPage .lch-rank-badge.top3 {
  background: #fcd5b5;
}

#learnChineseHubPage .lch-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 2200;
  background: rgba(15, 23, 42, 0.45);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 16px;
}

#learnChineseHubPage .lch-modal-overlay.show {
  display: flex;
}

#learnChineseHubPage .lch-modal-card {
  background: #fff;
  border-radius: 20px;
  padding: 20px 18px;
  width: 100%;
  max-width: 340px;
  max-height: 88vh;
  overflow: auto;
  text-align: center;
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.12);
}

#learnChineseHubPage .lch-modal-card h3 {
  margin: 0 0 8px;
  font-size: 17px;
}

#learnChineseHubPage .lch-modal-desc {
  margin: 0 0 12px;
  font-size: 14px;
  color: var(--text-secondary, #64748b);
}

#learnChineseHubPage .lch-textarea,
#learnChineseHubPage .lch-select {
  width: 100%;
  margin: 8px 0;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--border, #e2e8f0);
  font: inherit;
  box-sizing: border-box;
}

#learnChineseHubPage .lch-mt-8 {
  margin-top: 8px;
}

#learnChineseHubPage .lch-empty-tips {
  text-align: center;
  color: #94a3b8;
  font-size: 13px;
  padding: 8px 0 16px;
}

#learnChineseHubPage .lch-hub-toast {
  position: fixed;
  left: 50%;
  bottom: calc(100px + env(safe-area-inset-bottom, 0px));
  transform: translateX(-50%);
  z-index: 2300;
  min-width: 200px;
  max-width: 88vw;
  padding: 10px 16px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.88);
  color: #fff;
  font-size: 14px;
  text-align: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
}

#learnChineseHubPage .lch-hub-toast.show {
  opacity: 1;
}

/* ==================== 异乡角落 ==================== */
#cozyCornerPage {
  background: linear-gradient(180deg, #fff8f0 0%, var(--bg-primary) 100%);
}

#cozyCornerPage .cozy-header {
  border-bottom: 1px solid #ffe8d6;
}

#cozyCornerPage .cozy-main {
  padding-top: 10px;
  padding-bottom: 20px;
}

#cozyCornerPage .station-tab-bar {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  padding-bottom: 12px;
  scrollbar-width: none;
}

#cozyCornerPage .station-tab-bar::-webkit-scrollbar {
  display: none;
}

#cozyCornerPage .station-tab {
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 13px;
  color: var(--text-primary);
  white-space: nowrap;
}

#cozyCornerPage .station-tab.active {
  background: var(--warning);
  border-color: var(--warning);
  color: #fff;
}

#cozyCornerPage .deep-banner {
  width: 100%;
  text-align: left;
  border: 1px solid #f59e0b;
  background: #fef3c7;
  border-radius: 18px;
  padding: 12px 14px;
  color: #b45309;
  margin-bottom: 12px;
}

#cozyCornerPage .cozy-station.is-hidden {
  display: none;
}

#cozyCornerPage .mood-bar {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 8px;
  padding: 14px;
  background: #fff;
  border-radius: 20px;
  border: 1px solid var(--border);
  margin-bottom: 12px;
}

#cozyCornerPage .mood-emoji {
  border: none;
  background: transparent;
  font-size: 24px;
}

#cozyCornerPage .treehole-card {
  background: #fff;
  border: 1px solid #ffe8d6;
  border-radius: 20px;
  padding: 14px;
  margin-bottom: 12px;
}

#cozyCornerPage .cozy-card-text {
  margin: 10px 0;
}

#cozyCornerPage .tag-emo {
  background: #fef3c7;
  color: #b45309;
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 11px;
}

#cozyCornerPage .action-btn {
  border: none;
  background: transparent;
  color: var(--text-secondary);
  margin-right: 14px;
}

#cozyCornerPage .cozy-input-wrap {
  display: grid;
  gap: 8px;
}

#cozyCornerPage .cozy-input,
#cozyCornerPage .cozy-textarea {
  width: 100%;
  border: 1px solid #ffe8d6;
  border-radius: 16px;
  padding: 12px;
  background: #fff;
}

#cozyCornerPage .cozy-textarea {
  margin: 10px 0;
}

#cozyCornerPage .cozy-section-center {
  text-align: center;
}

#cozyCornerPage .cozy-hero-emoji {
  font-size: 42px;
  margin: 16px 0;
}

#cozyCornerPage .cozy-link-btn {
  border: none;
  background: transparent;
  color: var(--primary);
  font-weight: 600;
}

#cozyCornerPage .family-feature-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

#cozyCornerPage .family-card {
  border: 1px solid #ffe8d6;
  border-radius: 16px;
  background: #fff8f0;
  padding: 12px;
  text-align: center;
}

#cozyCornerPage .family-card i {
  font-size: 22px;
  color: var(--warning);
}

#cozyCornerPage .family-card div {
  margin-top: 6px;
  font-weight: 600;
}

#cozyCornerPage .family-card p {
  margin-top: 4px;
  font-size: 11px;
  color: var(--text-secondary);
}

#cozyCornerPage .growth-timeline-item {
  border-left: 2px solid var(--warning);
  padding-left: 12px;
  margin: 10px 0 10px 8px;
}

#cozyCornerPage .cozy-modal-card {
  width: min(330px, calc(100vw - 36px));
  text-align: center;
}

#cozyCornerPage .cozy-toast {
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  bottom: 98px;
  background: rgba(0, 0, 0, 0.72);
  color: #fff;
  padding: 10px 16px;
  border-radius: 999px;
  font-size: 13px;
  opacity: 0;
  transition: opacity 0.2s ease;
  pointer-events: none;
  z-index: 1400;
}

#cozyCornerPage .cozy-toast.show {
  opacity: 1;
}

#cozyCornerPage .cozy-mt-8 {
  margin-top: 8px;
}

/* 同乡站（原互助位，仍用 cozySwitchStation('mutual') + #cozyStationMutual） */
#cozyCornerPage .cozy-hometown-wrap {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
#cozyCornerPage .cozy-hometown-origin {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}
#cozyCornerPage .cozy-hometown-origin-label {
  font-weight: 600;
  color: var(--text-primary);
  font-size: 14px;
}
#cozyCornerPage .cozy-hometown-origin-label .fa-map-pin {
  color: #0d9488;
  margin-right: 4px;
}
#cozyCornerPage .cozy-hometown-pill {
  border: none;
  background: #f1f5f9;
  color: #1e293b;
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  font-family: inherit;
}
#cozyCornerPage .cozy-hometown-dual {
  display: flex;
  gap: 12px;
}
#cozyCornerPage .cozy-hometown-tile {
  flex: 1;
  min-width: 0;
  border: 1px solid #e2e8f0;
  border-radius: 20px;
  background: #fff;
  padding: 14px 8px;
  text-align: center;
  cursor: pointer;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.02);
  font-family: inherit;
}
#cozyCornerPage .cozy-hometown-tile i {
  font-size: 26px;
  color: #0d9488;
  display: block;
  margin-bottom: 8px;
}
#cozyCornerPage .cozy-hometown-tile-title {
  font-weight: 600;
  font-size: 14px;
  color: #1e293b;
}
#cozyCornerPage .cozy-hometown-tile-sub {
  font-size: 11px;
  color: #64748b;
  margin-top: 2px;
}
#cozyCornerPage .cozy-hometown-chips {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 4px 0 2px;
  scrollbar-width: none;
}
#cozyCornerPage .cozy-hometown-chips::-webkit-scrollbar {
  display: none;
}
#cozyCornerPage .cozy-hometown-chip {
  flex: 0 0 auto;
  border: none;
  background: #f1f5f9;
  color: #1e293b;
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 13px;
  white-space: nowrap;
  cursor: pointer;
  font-family: inherit;
}
#cozyCornerPage .cozy-hometown-chip--active {
  background: #0d9488;
  color: #fff;
}
#cozyCornerPage .cozy-hometown-card-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}
#cozyCornerPage .cozy-hometown-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 600;
  color: #334155;
  flex-shrink: 0;
}
#cozyCornerPage .cozy-hometown-tag {
  margin-left: 6px;
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 999px;
  background: #f1f5f9;
  color: #475569;
  font-weight: 500;
}
#cozyCornerPage .cozy-hometown-tag--ok {
  background: #ccfbf1;
  color: #0f766e;
}
#cozyCornerPage .cozy-hometown-card-title {
  font-weight: 600;
  font-size: 15px;
  color: #1e293b;
  margin-bottom: 4px;
  line-height: 1.35;
}
#cozyCornerPage .cozy-hometown-pill-tag {
  display: inline-block;
  background: #fef3c7;
  color: #92400e;
  font-size: 12px;
  padding: 2px 8px;
  border-radius: 8px;
  margin-right: 6px;
  font-weight: 600;
}
#cozyCornerPage .cozy-hometown-card-meta {
  font-size: 12px;
  color: #64748b;
  margin-bottom: 4px;
}
#cozyCornerPage .cozy-hometown-card-body {
  margin-top: 6px;
  line-height: 1.45;
}
#cozyCornerPage .cozy-hometown-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px 20px;
  margin-top: 12px;
  color: #64748b;
}
#cozyCornerPage .cozy-hometown-act {
  border: none;
  background: transparent;
  padding: 0;
  font: inherit;
  color: inherit;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
}
#cozyCornerPage .cozy-hometown-act i {
  font-size: 15px;
}
#cozyCornerPage .cozy-hometown-footnote {
  text-align: center;
  font-size: 12px;
  color: #64748b;
  padding: 4px 0 8px;
  margin: 0;
}

/* 乡愁市集弹层 */
#cozyHometownMarketModal.show {
  z-index: 1200;
}
#cozyMarketPostModal.show {
  z-index: 1210;
}
#cozyHometownMarketModal .cozy-market-modal {
  width: min(440px, calc(100vw - 28px));
  max-height: min(88vh, 720px);
  display: flex;
  flex-direction: column;
  text-align: left;
  overflow: hidden;
  padding: 16px 16px 14px;
}
#cozyMarketPostModal .cozy-market-post-card {
  width: min(400px, calc(100vw - 28px));
  max-height: min(90vh, 640px);
  overflow-y: auto;
  text-align: left;
  padding: 16px 16px 14px;
}
#cozyHometownMarketModal .cozy-market-header,
#cozyMarketPostModal .cozy-market-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}
#cozyHometownMarketModal .cozy-market-header h3,
#cozyMarketPostModal .cozy-market-header h3 {
  margin: 0;
  font-size: 17px;
  color: #0f766e;
}
#cozyHometownMarketModal .cozy-market-lead {
  font-size: 12px;
  color: #64748b;
  margin: 0 0 12px;
  line-height: 1.45;
}
#cozyHometownMarketModal .cozy-market-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
#cozyHometownMarketModal .cozy-market-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  flex: 1;
  min-width: 0;
}
#cozyHometownMarketModal .cozy-market-filter-btn {
  border: 1px solid #e2e8f0;
  background: #fff;
  color: #475569;
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 12px;
  cursor: pointer;
  font-family: inherit;
}
#cozyHometownMarketModal .cozy-market-filter-btn.active {
  background: #0d9488;
  border-color: #0d9488;
  color: #fff;
}
#cozyHometownMarketModal .cozy-market-post-btn {
  flex-shrink: 0;
  border-radius: 999px;
  padding: 8px 14px;
  font-size: 13px;
}
#cozyHometownMarketModal .cozy-market-list {
  flex: 1;
  min-height: 100px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding-right: 2px;
}
#cozyHometownMarketModal .cozy-market-empty {
  text-align: center;
  color: #64748b;
  font-size: 13px;
  padding: 20px 8px;
}
#cozyHometownMarketModal .cozy-market-row {
  display: flex;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid #f1f5f9;
}
#cozyHometownMarketModal .cozy-market-row:last-child {
  border-bottom: none;
}
#cozyHometownMarketModal .cozy-market-row-main {
  flex: 1;
  min-width: 0;
}
#cozyHometownMarketModal .cozy-market-type {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  color: #0f766e;
  background: #ccfbf1;
  padding: 2px 8px;
  border-radius: 6px;
  margin-bottom: 6px;
}
#cozyHometownMarketModal .cozy-market-row-title {
  font-weight: 600;
  font-size: 14px;
  color: #1e293b;
  margin-bottom: 4px;
  line-height: 1.35;
}
#cozyHometownMarketModal .cozy-market-row-desc {
  font-size: 12px;
  color: #64748b;
  margin: 0 0 6px;
  line-height: 1.45;
}
#cozyHometownMarketModal .cozy-market-row-meta {
  font-size: 11px;
  color: #94a3b8;
}
#cozyHometownMarketModal .cozy-market-row-side {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
}
#cozyHometownMarketModal .cozy-market-price {
  font-size: 14px;
  font-weight: 700;
  color: #0d9488;
  white-space: nowrap;
}
#cozyHometownMarketModal .cozy-market-mine-actions {
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: stretch;
  width: 100%;
}
#cozyHometownMarketModal .cozy-market-mine-actions .btn {
  white-space: nowrap;
}
#cozyHometownMarketModal .cozy-market-del {
  border-color: #fecaca;
  color: #b91c1c;
}
#cozyMarketPostModal .cozy-market-form-label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: #475569;
  margin: 10px 0 4px;
}

/* ===== Mobile shell (≤768px): fixed top strip + compact bottom nav ===== */
@media (max-width: 768px) {
  /* 顶栏「内容区」与底栏「内容区」同一高度；安全区各自加在上下外沿 */
  :root {
    --mobile-chrome-row: 50px;
    --mobile-chrome-fab-bleed: 12px;
  }

  /* 顶栏固定：与底栏同高、同款毛玻璃（避免随页面滚动） */
  .page.active > .header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 95;
    width: 100%;
    max-width: 100%;
    margin: 0;
    box-sizing: border-box;
    min-height: calc(var(--safe-top) + var(--mobile-chrome-row));
    height: calc(var(--safe-top) + var(--mobile-chrome-row));
    padding-top: var(--safe-top);
    padding-bottom: 0;
    display: flex;
    align-items: center;
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--border-light);
    box-shadow: 0 4px 18px rgba(15, 23, 42, 0.06);
    will-change: auto;
  }

  /*
   * 分类/租房列表、信息详情：固定顶栏不用外层 flex（与子区 main.container 块级布局一致），
   * 避免标题左缘与下方卡片/空状态白块左缘不齐。
   */
  #categoryListPage.page.active > .header,
  #rentalListPage.page.active > .header,
  #listingDetailPage.page.active > .header {
    display: block;
  }
  #categoryListPage.page.active > .header > .container,
  #rentalListPage.page.active > .header > .container,
  #listingDetailPage.page.active > .header > .container {
    height: 100%;
    display: flex;
    align-items: center;
    box-sizing: border-box;
  }
  #categoryListPage.page.active > .header .header-content,
  #rentalListPage.page.active > .header .header-content,
  #listingDetailPage.page.active > .header .header-content {
    width: 100%;
    min-width: 0;
  }

  /* 攻略顶栏：与 .gcv2-container 同宽居中，不用全屏拉伸（避免与下方搜索/双卡列宽不一致） */
  #guidePage.gcv2-page > .gcv2-top-bar {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    transform: none;
    z-index: 95;
    width: 100%;
    max-width: 480px;
    margin-left: auto;
    margin-right: auto;
    box-sizing: border-box;
    min-height: calc(var(--safe-top) + var(--mobile-chrome-row));
    height: calc(var(--safe-top) + var(--mobile-chrome-row));
    padding-top: var(--safe-top);
    padding-bottom: 0;
    padding-left: var(--gcv2-gutter-x);
    padding-right: var(--gcv2-gutter-x);
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    justify-content: flex-end;
    gap: 8px;
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--border-light);
    box-shadow: 0 4px 18px rgba(15, 23, 42, 0.06);
    will-change: auto;
  }

  @media (min-width: 768px) {
    #guidePage.gcv2-page > .gcv2-top-bar {
      max-width: 600px;
    }
  }

  .page.active:not(#guidePage) > main,
  #guidePage.gcv2-page > main.gcv2-container {
    padding-top: calc(var(--safe-top) + var(--mobile-chrome-row) + 6px);
  }

  /* 我的页面顶部无功能：去掉空白顶栏，内容直接贴顶（保留安全区） */
  #userPage.page.active > .header.hub-profile-top-header {
    display: none;
  }
  #userPage.page.active > main.hub-profile-main {
    padding-top: calc(var(--safe-top) + 6px);
  }

  /* 底栏总高 + 中间凸起：为固定底栏预留滚动底部留白 */
  body {
    padding-bottom: calc(var(--mobile-chrome-row) + var(--safe-bottom) + var(--mobile-chrome-fab-bleed));
  }

  .bottom-nav {
    box-sizing: border-box;
    height: calc(var(--mobile-chrome-row) + var(--safe-bottom));
    min-height: calc(var(--mobile-chrome-row) + var(--safe-bottom));
    padding: 0 6px var(--safe-bottom);
    align-items: center;
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-top: 1px solid var(--border-light);
    box-shadow: 0 -4px 18px rgba(15, 23, 42, 0.06);
    overflow: visible;
    will-change: auto;
  }

  .bottom-nav .nav-item {
    height: auto;
    min-height: 0;
    padding: 3px 2px 2px;
    gap: 2px;
    border-radius: 12px;
  }

  .bottom-nav .nav-item::before {
    height: 2px;
    width: 26px;
  }

  .bottom-nav .nav-icon {
    font-size: 20px;
  }

  .bottom-nav .nav-icon-svg {
    width: 20px;
    height: 20px;
  }

  .bottom-nav .nav-label {
    font-size: 10px;
    line-height: 1.1;
    font-weight: 500;
  }

  .bottom-nav .nav-item--publish-hub {
    transform: translateY(-8px);
    max-width: 76px;
    gap: 3px;
  }
  .bottom-nav .nav-item--publish-hub .nav-publish-hub-circle {
    width: 48px;
    height: 48px;
    box-shadow: 0 6px 16px rgba(13, 148, 136, 0.3);
  }
  .bottom-nav .nav-item--publish-hub .nav-publish-hub-circle .fas {
    font-size: 22px;
  }
  .bottom-nav .nav-item--publish-hub .nav-label {
    font-size: 10px;
  }

  #cozyCornerPage .cozy-toast {
    bottom: calc(var(--mobile-chrome-row) + var(--safe-bottom) + var(--mobile-chrome-fab-bleed) + 8px);
  }

  /* 搜索框不展示自定义 ×：手机用系统键盘删除；避免与 type=search 控件叠两层 */
  #homePage .search-bar .search-clear,
  #guidePage .gcv2-search .search-clear {
    display: none !important;
    visibility: hidden;
    width: 0 !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden;
    pointer-events: none;
    position: absolute;
    opacity: 0;
  }
}
