/* ===== 柬埔寨情报站 · 自定义样式 ===== */

html, body {
    overscroll-behavior-y: none;
}
body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    background-color: #f6f6ef;
}

/* 列表卡片防误选文字（安卓触屏优化） */
#item-list li {
    -webkit-user-select: none;
    user-select: none;
    -webkit-tap-highlight-color: transparent;
}

/* hover 效果只在真实鼠标设备上触发，不影响触屏滑动 */
@media (hover: hover) {
    #item-list li:hover {
        background-color: rgba(255, 102, 0, 0.05);
    }
}

.scrollbar-none::-webkit-scrollbar {
    display: none;
}

.tab-btn {
    color: #64748b;
    border-bottom: 2px solid transparent;
    transition: color 0.15s, border-color 0.15s;
    opacity: 1 !important;
}
.tab-btn:hover {
    color: #334155;
}
.tab-btn.active {
    border-bottom: 2px solid #ff6600;
    font-weight: 700;
    color: #ff6600 !important;
}

/* 平板导航滚动：右侧渐隐提示可横滑 */
.nav-scroll-fade {
    -webkit-mask-image: linear-gradient(to right, #000 90%, transparent 100%);
    mask-image: linear-gradient(to right, #000 90%, transparent 100%);
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
}
/* 大屏不需要渐隐 */
@media (min-width: 1100px) {
    .nav-scroll-fade {
        -webkit-mask-image: none;
        mask-image: none;
    }
}

.line-clamp-2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-clamp: 2;
}

.active-item {
    border-left: 3px solid #ff6600 !important;
    background-color: rgba(255, 102, 0, 0.03);
}

/* ===== Detail Link ===== */
.detail-link {
    color: inherit;
    text-decoration: none;
}
.detail-link:hover h3,
.detail-link:focus h3 {
    color: #ff6600;
    text-decoration: underline;
    text-underline-offset: 2px;
}
.detail-pill {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 10px;
    font-weight: 700;
    color: #94a3b8;
    border: 1px solid #e2e8f0;
    border-radius: 4px;
    padding: 1px 6px;
    white-space: nowrap;
    transition: color 0.15s, border-color 0.15s;
    text-decoration: none;
}
.detail-pill:hover {
    color: #ff6600;
    border-color: #ff6600;
}
/* ===== Card Tag Link ===== */
.tag-link {
    font-size: 9px;
    font-weight: 600;
    color: #94a3b8;
    text-decoration: none;
    transition: color 0.15s;
}
.tag-link:hover {
    color: #ff6600;
}
[data-theme="dark"] .tag-link {
    color: #64748b;
}
[data-theme="dark"] .tag-link:hover {
    color: #ff6600;
}

/* ===== Mobile Card Fix ===== */
@media (max-width: 639px) {
    .card-inner {
        flex-wrap: wrap;
    }
    .card-right {
        flex-direction: row !important;
        align-items: center !important;
        flex-wrap: wrap;
        gap: 4px 6px;
        min-width: 0 !important;
        width: 100%;
        padding-left: 28px;
        margin-top: 2px;
    }
    .card-title-row h3 {
        flex: 1 1 0;
        min-width: 0;
        white-space: normal;
        overflow: hidden;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        line-clamp: 2;
        -webkit-box-orient: vertical;
        text-overflow: unset;
    }
}

/* ── 管理员删除按钮 ── */
.admin-del-btn {
    display: inline-flex; align-items: center; justify-content: center;
    background: rgba(239,68,68,0.08);
    border: 1px solid rgba(239,68,68,0.2);
    border-radius: 4px;
    padding: 0 4px;
    font-size: 11px; line-height: 20px;
    cursor: pointer; color: #ef4444;
    flex-shrink: 0;
    transition: background .15s;
}
.admin-del-btn:hover { background: rgba(239,68,68,0.18); }

/* ── 收藏按钮 ── */
.fav-btn {
    display: inline-flex; align-items: center; justify-content: center;
    width: 18px; height: 18px;
    border: none; background: none;
    border-radius: 50%;
    cursor: pointer; color: #cbd5e1;
    flex-shrink: 0;
    transition: color 0.2s, transform 0.2s;
    padding: 0;
}
.fav-btn:hover { color: #f59e0b; transform: scale(1.15); }
.fav-btn.is-fav { color: #f59e0b; }
.fav-btn.is-fav svg { fill: currentColor; }

/* ── 编号列小删除按钮 ── */
.admin-del-btn-sm {
    display: inline-flex; align-items: center; justify-content: center;
    width: 18px; height: 18px;
    border: none; background: none;
    border-radius: 50%;
    cursor: pointer; color: #e2e8f0;
    flex-shrink: 0;
    font-size: 10px; line-height: 1;
    padding: 0;
    transition: color 0.2s, transform 0.2s;
}
.admin-del-btn-sm:hover { color: #ef4444; transform: scale(1.15); }

/* ── 置顶按钮 ── */
.admin-pin-btn-sm {
    display: inline-flex; align-items: center; justify-content: center;
    width: 18px; height: 18px;
    border: none; background: none;
    border-radius: 50%;
    cursor: pointer; color: #e2e8f0;
    flex-shrink: 0;
    font-size: 10px; line-height: 1;
    padding: 0;
    transition: color 0.2s, transform 0.2s;
}
.admin-pin-btn-sm:hover { color: #f59e0b; transform: scale(1.15); }

/* ── 置顶卡片高亮 ── */
.pinned-item {
    border-left: 3px solid #f59e0b !important;
    background: rgba(245, 158, 11, 0.04) !important;
}
[data-theme="dark"] .pinned-item {
    background: rgba(245, 158, 11, 0.06) !important;
    border-left-color: #f59e0b !important;
}

/* ===== Mobile Nav ===== */
.m-header {
    background: #ffffff;
    box-shadow: 0 1px 3px rgba(0,0,0,0.08);
    border-bottom: 1px solid #e2e8f0;
    max-width: 100vw;
    will-change: transform;
}
.m-action-btn {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 1px; padding: 4px 5px; border-radius: 6px;
    background: transparent; border: none;
    color: #64748b; font-size: 9px; font-weight: 600;
    cursor: pointer; transition: background 0.18s, color 0.18s;
    letter-spacing: 0; line-height: 1; flex-shrink: 0;
}
.m-action-btn svg { width: 15px; height: 15px; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; fill: none; }
.m-action-btn:hover, .m-action-btn.active { background: rgba(255,102,0,0.08); color: #ff6600; }

/* ── 手机端纯图标按钮（主题/搜索等） ── */
.m-icon-btn {
    display: inline-flex; align-items: center; justify-content: center;
    width: 30px; height: 30px; border-radius: 50%;
    background: transparent; border: none;
    color: #64748b; cursor: pointer;
    transition: background 0.18s, color 0.18s;
    flex-shrink: 0;
}
.m-icon-btn:hover { background: rgba(255,102,0,0.08); color: #ff6600; }

/* 搜索栏带动画 */
#m-search-bar {
    overflow: hidden; max-height: 0;
    transition: max-height 0.28s cubic-bezier(0.4,0,0.2,1);
}
#m-search-bar.open { max-height: 64px; }
.m-search-inner {
    display: flex; align-items: center; gap: 8px;
    padding: 10px 16px;
}
.m-search-inner input {
    flex: 1; background: #f1f5f9; border: 1.5px solid #e2e8f0;
    border-radius: 999px; padding: 8px 16px; color: #1e293b; font-size: 14px; outline: none;
    font-family: inherit; transition: border-color 0.18s, box-shadow 0.18s;
}
.m-search-inner input::placeholder { color: #94a3b8; }
.m-search-inner input:focus { border-color: #ff6600; box-shadow: 0 0 0 3px rgba(255,102,0,0.12); background: #fff; }
.m-search-confirm {
    background: #ff6600; border: none;
    border-radius: 8px; padding: 8px 16px; color: #fff; font-size: 13px;
    font-weight: 700; cursor: pointer; white-space: nowrap; font-family: inherit;
    flex-shrink: 0;
}
.m-search-confirm:hover { background: #e55200; }
#m-nav-panel {
    background: #ffffff;
    border-top: 1px solid #e2e8f0;
    box-shadow: 0 4px 16px rgba(0,0,0,0.06);
}
.tab-btn-m {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    color: #334155;
    border-radius: 10px;
    padding: 8px 14px;
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
    cursor: pointer;
    transition: all 0.15s;
    letter-spacing: 0.01em;
}
.tab-btn-m svg {
    color: #94a3b8;
    transition: color 0.15s;
}
.tab-btn-m:hover {
    background: #fff7ed;
    border-color: #fed7aa;
    color: #ea580c;
}
.tab-btn-m:hover svg {
    color: #ea580c;
}
.tab-btn-m.active-m {
    background: linear-gradient(135deg, #ff6600, #ea580c);
    color: #fff;
    font-weight: 700;
    border-color: transparent;
    box-shadow: 0 2px 8px rgba(255,102,0,0.25);
}
.tab-btn-m.active-m svg {
    color: #fff;
}

/* ── 标签云 ── */
.tag-cloud-wrap {
    overflow-x: auto;
    white-space: nowrap;
    scrollbar-width: none;
    margin-bottom: 10px;
    padding: 2px 0 6px;
}
.tag-cloud-wrap::-webkit-scrollbar { display: none; }

/* ── 手机分类横滑条 ── */
#m-cat-bar {
    position: relative;
    z-index: 1;               /* 低于顶部操作行，避免遮挡下拉层 */
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}
/* 手机顶部操作行（搜索框 / 用户菜单所在行）须高于分类条 */
.m-header {
    position: relative;
    z-index: 2;
}
#m-cat-bar::-webkit-scrollbar { display: none; }
.tab-btn-m-strip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 36px;
    padding: 0 13px;
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    color: #64748b;
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
    cursor: pointer;
    transition: color 0.15s, border-color 0.15s;
    flex-shrink: 0;
    letter-spacing: 0.01em;
}
.tab-btn-m-strip:hover { color: #334155; }
.tab-btn-m-strip.active-m {
    color: #ff6600;
    border-bottom-color: #ff6600;
    font-weight: 700;
}
.tag-chip {
    display: inline-flex;
    align-items: center;
    font-size: 11px;
    font-weight: 700;
    color: #64748b;
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 100px;
    padding: 3px 11px;
    margin-right: 6px;
    cursor: pointer;
    transition: all 0.15s;
    white-space: nowrap;
    user-select: none;
}
.tag-chip:hover, .tag-chip.active-tag {
    background: #ff6600;
    color: #fff;
    border-color: #ff6600;
    box-shadow: 0 2px 8px rgba(255,102,0,0.25);
}
.tag-chip .tag-cnt {
    display: inline-block;
    margin-left: 4px;
    font-size: 9px;
    opacity: 0.65;
    font-weight: 600;
}

/* ===== Skeleton Screen ===== */
@keyframes shimmer {
    0% { background-position: -400px 0; }
    100% { background-position: 400px 0; }
}
.skeleton-row {
    display: flex;
    align-items: center;
    padding: 14px 0;
    border-bottom: 1px solid #f1f5f9;
}
.skeleton-bone {
    background: linear-gradient(90deg, #f1f5f9 25%, #e8ecf1 37%, #f1f5f9 63%);
    background-size: 800px 100%;
    animation: shimmer 1.6s ease-in-out infinite;
    border-radius: 4px;
    flex-shrink: 0;
}
.skeleton-num {
    width: 18px; height: 14px; margin-right: 10px;
}
.skeleton-badge {
    width: 36px; height: 16px; margin-right: 8px; border-radius: 3px;
}
.skeleton-title {
    height: 14px; flex: 1; min-width: 0; margin-right: 16px;
}
.skeleton-meta {
    height: 10px; width: 60px; margin-right: 8px;
}
.skeleton-tag {
    height: 12px; width: 44px; border-radius: 2px;
}
/* 不同行宽度变化，看起来更自然 */
.skeleton-row:nth-child(odd) .skeleton-title { max-width: 70%; }
.skeleton-row:nth-child(even) .skeleton-title { max-width: 55%; }
.skeleton-row:nth-child(3n) .skeleton-meta { width: 80px; }



/* ── 用户菜单 dropdown 动画 ── */
#user-menu {
    animation: menuFadeIn 0.15s ease-out;
}
@keyframes menuFadeIn {
    from { opacity: 0; transform: translateY(-6px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ── 广告卡片 ── */
/* ── 推广：通用 ── */
/* ── 广告统一卡片样式（与内容卡片同布局）── */
.promo-item {
    position: relative; cursor: pointer; list-style: none;
    background: linear-gradient(135deg, #fffbeb, #fef3c7);
    border: 1px solid #fde68a; border-radius: 8px;
    padding: 8px 4px; margin: 6px 0;
    transition: all 0.2s;
    border-top: none !important; /* override divide-y */
}
.promo-item + li { border-top: none !important; }
.promo-item:hover {
    border-color: #f59e0b;
    box-shadow: 0 2px 10px rgba(245,158,11,.15);
    transform: translateY(-1px);
}
/* 推广标签 */
.promo-badge {
    display: inline-block; font-size: 9px; color: #d97706;
    font-weight: 700; background: rgba(217,119,6,.12); padding: 1px 6px;
    border-radius: 3px; letter-spacing: .5px; white-space: nowrap;
}
/* 缩略图 */
.promo-thumb {
    width: 48px; height: 36px; object-fit: cover; border-radius: 6px; flex-shrink: 0;
}
/* 横幅内嵌 */
.promo-banner-inner {
    position: relative; border-radius: 6px; overflow: hidden;
    height: 48px;
}
.promo-banner-inner img {
    width: 100%; height: 100%; object-fit: cover; display: block;
}
.promo-banner-overlay {
    position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, rgba(0,0,0,.4), rgba(0,0,0,.1));
}
.promo-banner-title {
    color: #fff; font-size: 13px; font-weight: 800;
    text-shadow: 0 1px 3px rgba(0,0,0,.5); text-align: center;
}
/* 轮播 */
.promo-slides {
    display: flex; gap: 6px; overflow-x: auto; scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch; scrollbar-width: none; margin-top: 4px;
}
.promo-slides::-webkit-scrollbar { display: none; }
.promo-slides img {
    width: 120px; height: 48px; object-fit: cover; border-radius: 6px;
    scroll-snap-align: start; flex-shrink: 0;
}
@media (min-width: 640px) {
    .promo-slides img { width: 180px; height: 56px; }
    .promo-banner-inner { height: 56px; }
    .promo-thumb { width: 56px; height: 42px; }
}

/* ── 动画 ── */
@keyframes fadeIn { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }
@keyframes slideUp { from { opacity: 0; transform: translate(-50%, 20px); } to { opacity: 1; transform: translate(-50%, 0); } }

/* ═══════════════════════════════════════════════════════════════
   🌙 暗色主题 · CSS 变量 + Tailwind 类覆写
   只需在 <html> 上切换 data-theme="dark" 即可，无需改 JS 模板
═══════════════════════════════════════════════════════════════ */

/* ── 主题变量 ── */
:root {
    --th-bg:         #f6f6ef;
    --th-bg-card:    #ffffff;
    --th-bg-hover:   rgba(255,102,0,0.04);
    --th-bg-modal:   #ffffff;
    --th-bg-muted:   #f8fafc;
    --th-bg-input:   #f1f5f9;
    --th-border:     #e2e8f0;
    --th-border-light: #f1f5f9;
    --th-text-primary:   #0f172a;
    --th-text-secondary: #334155;
    --th-text-muted:     #64748b;
    --th-text-faint:     #94a3b8;
    --th-text-disabled:  #cbd5e1;
    --th-shadow:     0 1px 3px rgba(0,0,0,0.06);
    --th-header-bg:  #ff6600;
    --th-header-glow: rgba(255,102,0,0.35);
}

[data-theme="dark"] {
    --th-bg:         #0f0f14;
    --th-bg-card:    #1a1a24;
    --th-bg-hover:   rgba(255,102,0,0.08);
    --th-bg-modal:   #1e1e2a;
    --th-bg-muted:   #16161f;
    --th-bg-input:   #22222e;
    --th-border:     #2a2a3a;
    --th-border-light: #1f1f2e;
    --th-text-primary:   #f1f5f9;
    --th-text-secondary: #cbd5e1;
    --th-text-muted:     #94a3b8;
    --th-text-faint:     #64748b;
    --th-text-disabled:  #475569;
    --th-shadow:     0 2px 8px rgba(0,0,0,0.4);
    --th-header-bg:  #1a1015;
    --th-header-glow: rgba(255,102,0,0.15);
    color-scheme: dark;
}

/* ── 核心元素 ── */
[data-theme="dark"] body {
    background-color: var(--th-bg) !important;
    color: var(--th-text-primary) !important;
}

/* ── Tailwind 文字色覆写 ── */
[data-theme="dark"] .text-slate-900  { color: var(--th-text-primary) !important; }
[data-theme="dark"] .text-slate-800  { color: #e2e8f0 !important; }
[data-theme="dark"] .text-slate-700  { color: var(--th-text-secondary) !important; }
[data-theme="dark"] .text-slate-600  { color: #94a3b8 !important; }
[data-theme="dark"] .text-slate-500  { color: var(--th-text-muted) !important; }
[data-theme="dark"] .text-slate-400  { color: var(--th-text-faint) !important; }
[data-theme="dark"] .text-slate-300  { color: #64748b !important; }

/* ── Tailwind 背景色覆写 ── */
[data-theme="dark"] .bg-white        { background-color: var(--th-bg-card) !important; }
[data-theme="dark"] .bg-white\/95    { background-color: rgba(26,26,36,0.95) !important; }
[data-theme="dark"] .bg-slate-50     { background-color: var(--th-bg-muted) !important; }
[data-theme="dark"] .bg-slate-100    { background-color: #1e1e2a !important; }
[data-theme="dark"] .bg-gray-100     { background-color: #1e1e2a !important; }
[data-theme="dark"] .bg-gray-50      { background-color: #22222e !important; }
[data-theme="dark"] .border-gray-200 { border-color: #2a2a3a !important; }
[data-theme="dark"] .focus-within\:border-orange-300:focus-within { border-color: rgba(255,102,0,0.4) !important; }
[data-theme="dark"] #search-input    { color: #f1f5f9 !important; }
[data-theme="dark"] #search-input::placeholder { color: #64748b !important; }

/* ── Tailwind 边框色覆写 ── */
[data-theme="dark"] .border-slate-100 { border-color: rgba(255,255,255,0.04) !important; }
[data-theme="dark"] .border-slate-100\/60 { border-color: rgba(255,255,255,0.03) !important; }
[data-theme="dark"] .border-slate-200 { border-color: var(--th-border) !important; }
[data-theme="dark"] .divide-slate-200 > :not([hidden]) ~ :not([hidden]) { border-color: var(--th-border) !important; }
[data-theme="dark"] .divide-slate-100 > :not([hidden]) ~ :not([hidden]) { border-color: rgba(255,255,255,0.04) !important; }
[data-theme="dark"] .border-t.border-slate-100 { border-color: rgba(255,255,255,0.04) !important; }

/* ── Tailwind hover 覆写 ── */
[data-theme="dark"] .hover\:bg-orange-50\/40:hover,
[data-theme="dark"] .hover\:bg-orange-50\/30:hover,
[data-theme="dark"] .hover\:bg-orange-50:hover { background-color: rgba(255,102,0,0.08) !important; }
[data-theme="dark"] .hover\:bg-slate-50:hover  { background-color: rgba(255,255,255,0.04) !important; }
[data-theme="dark"] .hover\:bg-slate-100:hover { background-color: rgba(255,255,255,0.06) !important; }
[data-theme="dark"] .hover\:bg-slate-200:hover { background-color: rgba(255,255,255,0.08) !important; }
[data-theme="dark"] .hover\:text-slate-900:hover { color: var(--th-text-primary) !important; }
[data-theme="dark"] .hover\:text-slate-600:hover { color: #94a3b8 !important; }
[data-theme="dark"] .hover\:bg-blue-50:hover   { background-color: rgba(37,99,235,0.1) !important; }
[data-theme="dark"] .hover\:bg-purple-50:hover  { background-color: rgba(139,92,246,0.1) !important; }
[data-theme="dark"] .hover\:bg-red-50:hover     { background-color: rgba(239,68,68,0.1) !important; }

/* ── 背景色 alpha 系列 ── */
[data-theme="dark"] .bg-slate-900\/40 { background-color: rgba(0,0,0,0.6) !important; }

/* ── Header 暗色 ── */
[data-theme="dark"] header.bg-white { background: linear-gradient(135deg, #1a1520 0%, #0f0f14 100%) !important; color: #f1f5f9 !important; border-bottom-color: transparent !important; }
[data-theme="dark"] .m-header { background: linear-gradient(135deg, #1e1525 0%, #12101a 100%) !important; box-shadow: 0 2px 12px rgba(255,102,0,0.1) !important; border-bottom-color: transparent !important; }
[data-theme="dark"] .m-action-btn { color: rgba(255,255,255,0.75); }
[data-theme="dark"] .m-action-btn:hover, [data-theme="dark"] .m-action-btn.active { background: rgba(255,255,255,0.1); color: #fff; }
[data-theme="dark"] .m-icon-btn { color: rgba(255,255,255,0.65); }
[data-theme="dark"] .m-icon-btn:hover { background: rgba(255,255,255,0.1); color: #fff; }
[data-theme="dark"] #m-search-inline { background: #22222e !important; border-color: #2a2a3a !important; }
[data-theme="dark"] #m-search-inline input { color: #f1f5f9 !important; }
[data-theme="dark"] #m-search-inline input::placeholder { color: #64748b !important; }
[data-theme="dark"] #m-nav-panel { background: #16161f !important; border-top-color: #2a2a3a !important; box-shadow: 0 4px 16px rgba(0,0,0,0.3) !important; }
[data-theme="dark"] #m-cat-bar { background: linear-gradient(135deg, #1e1525 0%, #12101a 100%) !important; border-top-color: rgba(255,255,255,0.06) !important; }
[data-theme="dark"] .tab-btn-m-strip { color: rgba(255,255,255,0.55); }
[data-theme="dark"] .tab-btn-m-strip:hover { color: rgba(255,255,255,0.85); }
[data-theme="dark"] .tab-btn-m-strip.active-m { color: #ff6600; border-bottom-color: #ff6600; }
[data-theme="dark"] .tab-btn-m { background: #1e1e2e; border-color: #2a2a3a; color: #cbd5e1; }
[data-theme="dark"] .tab-btn-m svg { color: #64748b; }
[data-theme="dark"] .tab-btn-m:hover { background: rgba(255,102,0,0.1); border-color: rgba(255,102,0,0.25); color: #fb923c; }
[data-theme="dark"] .tab-btn-m:hover svg { color: #fb923c; }
[data-theme="dark"] .tab-btn-m.active-m { background: linear-gradient(135deg,#ff6600,#ea580c); color: #fff; border-color: transparent; }
[data-theme="dark"] .tab-btn-m.active-m svg { color: #fff; }

/* ── 搜索框 ── */
[data-theme="dark"] .m-search-inner input {
    background: var(--th-bg-input) !important;
    border-color: var(--th-border) !important;
    color: var(--th-text-primary) !important;
}
[data-theme="dark"] .m-search-inner input:focus {
    background: var(--th-bg-card) !important;
    border-color: #ff6600 !important;
}

/* ── 模态框 ── */
[data-theme="dark"] #modal-content {
    background-color: var(--th-bg-modal) !important;
    border-color: var(--th-border) !important;
}
/* 关闭按钮 */
[data-theme="dark"] #modal-content button.hover\:bg-slate-100:hover {
    background-color: rgba(255,255,255,0.08) !important;
}
/* 模态框标题 */
[data-theme="dark"] #modal-body h2 {
    color: var(--th-text-primary) !important;
}
/* 字段网格区域 border */
[data-theme="dark"] #modal-body .border-b {
    border-color: var(--th-border) !important;
}
/* 字段图标容器 */
[data-theme="dark"] #modal-body .bg-slate-50 {
    background-color: var(--th-bg-muted) !important;
    border-color: var(--th-border) !important;
}
/* 字段图标 */
[data-theme="dark"] #modal-body .text-slate-400 {
    color: var(--th-text-faint) !important;
}
/* 字段标签 (dt) */
[data-theme="dark"] #modal-body .text-slate-300,
[data-theme="dark"] #modal-body dt {
    color: var(--th-text-faint) !important;
}
/* 字段值 (dd) */
[data-theme="dark"] #modal-body dd.text-slate-700,
[data-theme="dark"] #modal-body .text-slate-700 {
    color: var(--th-text-secondary) !important;
}
/* 摘要内容 */
[data-theme="dark"] #modal-body .text-slate-600 {
    color: #94a3b8 !important;
}
/* 完整原文区块 */
[data-theme="dark"] #modal-body .bg-slate-50.border-slate-100,
[data-theme="dark"] #modal-body .bg-slate-50\/50 {
    background-color: var(--th-bg-muted) !important;
    border-color: var(--th-border) !important;
    color: var(--th-text-secondary) !important;
}
/* 完整原文内的 text-slate-700 */
[data-theme="dark"] #modal-body .text-sm.text-slate-700 {
    color: var(--th-text-secondary) !important;
}
/* 使用条件区块 */
[data-theme="dark"] #modal-body .bg-pink-50\/30 {
    background-color: rgba(236,72,153,0.06) !important;
    border-color: rgba(236,72,153,0.15) !important;
    color: #94a3b8 !important;
}
/* 任职要求区块 */
[data-theme="dark"] #modal-body .bg-slate-50\/50 {
    background-color: var(--th-bg-muted) !important;
    border-color: var(--th-border) !important;
    color: var(--th-text-secondary) !important;
}
/* 联系方式区块 */
[data-theme="dark"] #modal-body .bg-orange-50\/50 {
    background-color: rgba(255,102,0,0.06) !important;
    border-color: rgba(255,102,0,0.15) !important;
    color: #fdba74 !important;
}
[data-theme="dark"] #modal-body .text-orange-900 {
    color: #fdba74 !important;
}
/* 底部操作栏 */
[data-theme="dark"] #modal-body .border-t {
    border-color: var(--th-border) !important;
}
/* 来源标签 */
[data-theme="dark"] #modal-body .text-slate-300.font-mono {
    color: var(--th-text-faint) !important;
}
/* 分享链接按钮 */
[data-theme="dark"] #modal-body a.bg-slate-100 {
    background-color: var(--th-bg-input) !important;
    color: var(--th-text-secondary) !important;
}
[data-theme="dark"] #modal-body a.bg-slate-100:hover {
    background-color: rgba(255,255,255,0.1) !important;
}
/* 查看原文按钮 */
[data-theme="dark"] #modal-body a.bg-slate-900 {
    background-color: #ff6600 !important;
    color: #fff !important;
}
[data-theme="dark"] #modal-body a.bg-slate-900:hover {
    background-color: #e85d04 !important;
}
/* 绿色薪资文字 */
[data-theme="dark"] #modal-body .text-green-700 {
    color: #86efac !important;
}
/* 粉色优惠文字 */
[data-theme="dark"] #modal-body .text-pink-600 {
    color: #f9a8d4 !important;
}
/* 橙色查看原文链接 */
[data-theme="dark"] #modal-body a.text-orange-500 {
    color: #fb923c !important;
}
/* 弹窗内广告 */
[data-theme="dark"] #modal-body [id^="promo-modal-"] {
    border-top-color: var(--th-border) !important;
}
[data-theme="dark"] #modal-body [id^="promo-modal-"] div[style*="color:#d97706"] {
    color: #fb923c !important;
}
[data-theme="dark"] #modal-body [id^="promo-modal-"] div[style*="color:#92400e"] {
    color: #fdba74 !important;
}
[data-theme="dark"] #modal-body [id^="promo-modal-"] div[style*="color:#a16207"] {
    color: #94a3b8 !important;
}

/* ── 绿色薪资 badge ── */
[data-theme="dark"] .bg-green-100 { background-color: rgba(34,197,94,0.12) !important; }
[data-theme="dark"] .text-green-800 { color: #86efac !important; }
[data-theme="dark"] .border-green-200 { border-color: rgba(34,197,94,0.2) !important; }
[data-theme="dark"] .text-green-700 { color: #86efac !important; }

/* ── 橙色 badge ── */
[data-theme="dark"] .bg-orange-50  { background-color: rgba(255,102,0,0.08) !important; }
[data-theme="dark"] .bg-orange-50\/50 { background-color: rgba(255,102,0,0.06) !important; }
[data-theme="dark"] .border-orange-100 { border-color: rgba(255,102,0,0.15) !important; }
[data-theme="dark"] .text-orange-900   { color: #fdba74 !important; }

/* ── 粉色 badge ── */
[data-theme="dark"] .bg-pink-50\/30 { background-color: rgba(236,72,153,0.06) !important; }
[data-theme="dark"] .border-pink-100 { border-color: rgba(236,72,153,0.15) !important; }
[data-theme="dark"] .text-pink-600 { color: #f9a8d4 !important; }

/* ── 卡片 / 列表项 ── */
[data-theme="dark"] .active-item {
    background-color: rgba(255,102,0,0.06) !important;
}

/* ── 标签筹 ── */
[data-theme="dark"] .tag-chip {
    background: var(--th-bg-card);
    border-color: var(--th-border);
    color: var(--th-text-muted);
}
[data-theme="dark"] .tag-chip:hover,
[data-theme="dark"] .tag-chip.active-tag {
    background: #ff6600;
    color: #fff;
    border-color: #ff6600;
    box-shadow: 0 2px 8px rgba(255,102,0,0.3);
}

/* ── 骨架屏 ── */
[data-theme="dark"] .skeleton-row { border-bottom-color: var(--th-border-light) !important; }
[data-theme="dark"] .skeleton-bone { background: linear-gradient(90deg, #1e1e2a 25%, #28283a 37%, #1e1e2a 63%) !important; background-size: 800px 100% !important; }

/* ── 页脚 ── */
[data-theme="dark"] footer,
[data-theme="dark"] footer.border-t.border-slate-100 { border-color: var(--th-border) !important; }

/* ── PWA Banner ── */
[data-theme="dark"] #pwa-banner {
    background-color: rgba(26,26,36,0.95) !important;
    border-color: var(--th-border) !important;
}
[data-theme="dark"] #ios-guide > div { background-color: var(--th-bg-modal) !important; }
[data-theme="dark"] #ios-guide .text-slate-700 { color: var(--th-text-secondary) !important; }

/* ── 用户菜单 ── */
[data-theme="dark"] #user-menu,
[data-theme="dark"] #m-user-menu {
    background: var(--th-bg-card) !important;
    border-color: var(--th-border) !important;
}
[data-theme="dark"] #user-menu a,
[data-theme="dark"] #user-menu button,
[data-theme="dark"] #m-user-menu a,
[data-theme="dark"] #m-user-menu button { color: var(--th-text-secondary) !important; }
[data-theme="dark"] #user-menu .border-t,
[data-theme="dark"] #m-user-menu .border-t { border-color: var(--th-border) !important; }
[data-theme="dark"] #user-menu .text-red-500,
[data-theme="dark"] #m-user-menu .text-red-500 { color: #f87171 !important; }

/* ── 广告卡片暗色 ── */
[data-theme="dark"] .promo-item {
    background: linear-gradient(135deg, rgba(255,102,0,0.06), rgba(255,102,0,0.03)) !important;
    border-color: rgba(255,102,0,0.15) !important;
}
[data-theme="dark"] .promo-item:hover { border-color: rgba(255,102,0,0.3) !important; }
[data-theme="dark"] .promo-badge { background: rgba(255,102,0,0.15) !important; color: #fb923c !important; }
[data-theme="dark"] .promo-item .text-amber-800 { color: #fdba74 !important; }
[data-theme="dark"] .promo-item .text-amber-700 { color: #fb923c !important; }
[data-theme="dark"] .promo-item .text-amber-500 { color: #fb923c !important; }
[data-theme="dark"] .promo-item .text-slate-700 { color: #94a3b8 !important; }

/* ── 主题切换按钮 ── */
.theme-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px; height: 28px;
    border: none;
    border-radius: 50%;
    background: rgba(0,0,0,0.06);
    color: #64748b;
    cursor: pointer;
    transition: background 0.2s, transform 0.2s;
    flex-shrink: 0;
    font-size: 14px;
    line-height: 1;
}
.theme-toggle:hover { background: rgba(0,0,0,0.1); transform: scale(1.1); }
[data-theme="dark"] .theme-toggle { background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.85); }
[data-theme="dark"] .theme-toggle:hover { background: rgba(255,255,255,0.15); }

/* ── 手机端主题按钮 ── */
.theme-toggle-m {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 1px; padding: 4px 6px; border-radius: 6px;
    background: transparent; border: none;
    color: #64748b; font-size: 9px; font-weight: 600;
    cursor: pointer; transition: background 0.18s, color 0.18s;
    letter-spacing: 0; line-height: 1; flex-shrink: 0;
}
.theme-toggle-m:hover { background: rgba(0,0,0,0.06); }

/* ── 平滑过渡 ── */
html[data-theme] body,
html[data-theme] header,
html[data-theme] .m-header,
html[data-theme] #m-nav-panel,
html[data-theme] #m-cat-bar,
html[data-theme] #modal-content,
html[data-theme] footer,
html[data-theme] .tag-chip,
html[data-theme] .skeleton-bone,
html[data-theme] #pwa-banner {
    transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}

/* ── 深色模式下滚动条 ── */
[data-theme="dark"] ::-webkit-scrollbar { width: 6px; }
[data-theme="dark"] ::-webkit-scrollbar-track { background: var(--th-bg); }
[data-theme="dark"] ::-webkit-scrollbar-thumb { background: #333; border-radius: 3px; }
[data-theme="dark"] ::-webkit-scrollbar-thumb:hover { background: #555; }

/* ── 实时生活指数卡片暗色覆写 ── */
[data-theme="dark"] #living-index .from-blue-50    { --tw-gradient-from: #1e2a4a; }
[data-theme="dark"] #living-index .to-indigo-100   { --tw-gradient-to:   #1a2060; }
[data-theme="dark"] #living-index .border-blue-200 { border-color: #2a3a7a !important; }
[data-theme="dark"] #living-index .text-indigo-500 { color: #818cf8 !important; }
[data-theme="dark"] #living-index .text-blue-800   { color: #a5b4fc !important; }
[data-theme="dark"] #living-index .text-blue-500   { color: #6366f1 !important; }

[data-theme="dark"] #living-index .from-amber-50   { --tw-gradient-from: #2a1f0a; }
[data-theme="dark"] #living-index .to-orange-100   { --tw-gradient-to:   #3a2010; }
[data-theme="dark"] #living-index .border-orange-200 { border-color: #7c4a1a !important; }
[data-theme="dark"] #living-index .text-amber-600  { color: #fbbf24 !important; }
[data-theme="dark"] #living-index .text-orange-800 { color: #fb923c !important; }
[data-theme="dark"] #living-index .text-orange-600 { color: #f97316 !important; }

[data-theme="dark"] #living-index .from-emerald-50 { --tw-gradient-from: #0a2a1e; }
[data-theme="dark"] #living-index .to-teal-100     { --tw-gradient-to:   #0f3028; }
[data-theme="dark"] #living-index .border-emerald-200 { border-color: #1a5c40 !important; }
[data-theme="dark"] #living-index .text-emerald-600 { color: #34d399 !important; }
[data-theme="dark"] #living-index .text-emerald-800 { color: #6ee7b7 !important; }

/* ── 互动反应条 ── */
.rxn-bar { display:flex; align-items:center; gap:3px; margin-top:5px; flex-wrap:wrap; }
.rxn-inline { display:inline-flex; align-items:center; vertical-align:middle; margin-left:5px; }
.rxn-item {
    display:inline-flex; align-items:center; gap:2px;
    font-size:10px; font-weight:700; color:#94a3b8;
    cursor:pointer; padding:1px 4px; border-radius:4px;
    transition:all .15s; user-select:none;
    border:1px solid transparent;
}
.rxn-item:hover { background:rgba(249,115,22,.08); color:#f97316; border-color:rgba(249,115,22,.2); }
.rxn-item.rxn-active { color:#f97316; }
.rxn-item[data-type="hot"].rxn-active    { color:#ef4444; }
.rxn-item[data-type="verified"].rxn-active { color:#22c55e; }
.rxn-item[data-type="scam"].rxn-active   { color:#dc2626; }
.rxn-item[data-type="want"].rxn-active   { color:#f59e0b; }
.rxn-n { font-size:10px; font-weight:700; }
.rxn-sep { color:#e2e8f0; font-size:10px; line-height:1; }
[data-theme="dark"] .rxn-item { color:#4b5563; }
[data-theme="dark"] .rxn-item:hover { background:rgba(249,115,22,.1); color:#fb923c; }
[data-theme="dark"] .rxn-item.rxn-active { color:#f97316; }
[data-theme="dark"] .rxn-item[data-type="hot"].rxn-active    { color:#f87171; }
[data-theme="dark"] .rxn-item[data-type="verified"].rxn-active { color:#4ade80; }
[data-theme="dark"] .rxn-item[data-type="scam"].rxn-active   { color:#f87171; }
[data-theme="dark"] .rxn-item[data-type="want"].rxn-active   { color:#fbbf24; }
[data-theme="dark"] .rxn-sep { color:#374151; }

/* ═══════════════════════════════════════════
   搜索自动补全下拉框
   ═══════════════════════════════════════════ */
.search-drop-wrap { position: relative; }
.search-drop {
    position: absolute;
    top: calc(100% + 5px);
    left: 0;
    right: 0;
    min-width: 260px;
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0,0,0,.13);
    z-index: 300;
    overflow: hidden;
}
/* 移动端搜索弹窗：fixed 全宽，不受 flex 容器宽度或分类条遮挡 */
#search-drop-m.search-drop {
    position: fixed;
    left: 8px;
    right: 8px;
    top: 82px;                /* 46px 顶行 + 36px 分类条 */
    width: auto;
    min-width: 0;
    max-height: calc(100vh - 100px);
    overflow-y: auto;
    z-index: 1000;
}
[data-theme="dark"] .search-drop {
    background: #1a1a24;
    border-color: #2a2a3a;
    box-shadow: 0 8px 32px rgba(0,0,0,.5);
}
.sdrop-inner { padding: 4px 0; }
.sdrop-section {
    padding: 7px 0 5px;
    border-bottom: 1px solid #f1f5f9;
}
.sdrop-section:last-child { border-bottom: none; }
[data-theme="dark"] .sdrop-section { border-bottom-color: #242434; }
.sdrop-label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 10px;
    font-weight: 700;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: .06em;
    padding: 0 12px 5px;
}
.sdrop-clear-btn {
    font-size: 10px;
    color: #94a3b8;
    cursor: pointer;
    font-weight: 600;
    text-transform: none;
    letter-spacing: 0;
    transition: color .15s;
}
.sdrop-clear-btn:hover { color: #ef4444; }
.sdrop-hist-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    padding: 0 12px 2px;
}
.sdrop-chip {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    border-radius: 100px;
    background: #f1f5f9;
    color: #475569;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    transition: all .15s;
    white-space: nowrap;
    max-width: 120px;
    overflow: hidden;
    text-overflow: ellipsis;
}
.sdrop-chip:hover { background: rgba(255,102,0,.1); color: #ff6600; }
[data-theme="dark"] .sdrop-chip { background: #22222e; color: #94a3b8; }
[data-theme="dark"] .sdrop-chip:hover { background: rgba(255,102,0,.12); color: #fb923c; }
.sdrop-item {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 6px 12px;
    cursor: pointer;
    transition: background .15s;
}
.sdrop-item:hover { background: rgba(255,102,0,.05); }
[data-theme="dark"] .sdrop-item:hover { background: rgba(255,102,0,.08); }
.sdrop-cat {
    flex-shrink: 0;
    font-size: 9px;
    font-weight: 800;
    color: #ea580c;
    background: rgba(249,115,22,.1);
    border-radius: 4px;
    padding: 1px 5px;
    letter-spacing: .04em;
}
.sdrop-ititle {
    flex: 1;
    min-width: 0;
    font-size: 12px;
    color: #334155;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
[data-theme="dark"] .sdrop-ititle { color: #94a3b8; }
.sdrop-ititle mark {
    background: rgba(255,102,0,.18);
    color: #ea580c;
    border-radius: 2px;
    padding: 0 1px;
    font-style: normal;
}
[data-theme="dark"] .sdrop-ititle mark { background: rgba(255,102,0,.25); color: #fb923c; }
.sdrop-full {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    cursor: pointer;
    font-size: 12px;
    color: #64748b;
    font-weight: 600;
    background: rgba(255,102,0,.03);
    border-top: 1px solid #f1f5f9;
    transition: background .15s, color .15s;
}
.sdrop-full:hover { background: rgba(255,102,0,.07); color: #ff6600; }
[data-theme="dark"] .sdrop-full {
    background: rgba(255,102,0,.04);
    border-top-color: #242434;
    color: #94a3b8;
}
[data-theme="dark"] .sdrop-full:hover { background: rgba(255,102,0,.1); color: #fb923c; }
