/* 修复 mini 页面图标下方文字链接无法点击问题 */
#sitesContainer .sites-title.overflowClip_1,
#sitesContainer .sites-title.overflowClip_1 a {
    pointer-events: auto !important;
    cursor: pointer !important;
}

.mini-sites-grid-wrap .sites-title.eta-marquee {
    text-align: center !important;
}

.mini-sites-grid-wrap .sites-title.eta-marquee.eta-marquee--auto {
    text-align: left !important;
}

/* 站点管理样式 */
.sites-controls {
    margin-bottom: 15px;
}

/* 全宽度：页面整体不产生横向滚动；允许内部组件自行横向滚动（例如搜索方案 tab）。 */
/* html,
body {
    max-width: 100vw;
    overflow-x: hidden;
} */

/* 全站内容宽度基准：搜索区与快捷区共用，保证不同宽度下比例/对齐一致。 */
@media screen and (max-width: 992px) {
    :root {
        /* 三段式布局：顶部搜索区 / 中部快捷区 / 底部 footer */
        /* 三段式比例 */
        --eta-header-vh: calc(53vh);
        --eta-sites-vh: calc(37vh);
        --eta-footer-vh: calc(10vh);
        /* 固定导航预留高度（用于顶部搜索区下移），可按需微调 */
        --eta-navbar-safe: 64px;
        /* 标题以下（ETASeminar 文字以下）整体下移量（默认值，具体页面可覆盖） */
        --eta-after-title-shift: 0px;
        /* footer 文本距离页面底部的留白（目标：约 10px） */
        --eta-footer-bottom-gap: 6px;

        /* 宽度基准：搜索区和快捷区拆开控制
        - 搜索区：宽屏时收窄
        - 快捷方式区：保持更宽的视觉 */
        --eta-search-width: min(85vw, 1080px);
        --eta-sites-width: min(80vw, 1180px);
        /* 兼容旧变量：未迁移的规则仍能工作（默认等同快捷区宽度）。 */
        --eta-content-width: var(--eta-sites-width);
        /* 搜索区字号：窄屏更小、宽屏更大 */
        --eta-search-font: clamp(14px, 1.1vw, 20px);
        /* 搜索框字号 */
        --eta-engine-font: clamp(14px, 1.0vw, 18px);
        /* 引擎字号 */
        --eta-title-font: clamp(28px, 2.2vw, 32px);
        --eta-engine-min: 72px;

        /* 横向滚动条/滑块预留：保证有无滚动条时高度一致，避免搜索区上下抖动 */
        /* --eta-hscroll-reserve: 16px; */
        /* --eta-stype-height: 48px; */
        --eta-engines-height: 60px;
    }
}

@media screen and (min-width: 992px) {
    :root {
        /* 三段式布局：顶部搜索区 / 中部快捷区 / 底部 footer */
        /* 三段式比例 */
        --eta-header-vh: calc(52vh);
        --eta-sites-vh: calc(38vh);
        --eta-footer-vh: calc(10vh);
        /* 固定导航预留高度（用于顶部搜索区下移），可按需微调 */
        --eta-navbar-safe: 64px;
        /* 标题以下（ETASeminar 文字以下）整体下移量（默认值，具体页面可覆盖） */
        --eta-after-title-shift: 0px;
        /* footer 文本距离页面底部的留白（目标：约 10px） */
        --eta-footer-bottom-gap: 6px;

        /* 宽屏：搜索框宽度约为页面宽度 85% */
        --eta-search-width: min(85vw, 1280px);
        --eta-sites-width: min(80vw, 1280px);
        --eta-content-width: var(--eta-sites-width);
        /* 搜索区字号：窄屏更小、宽屏更大 */
        --eta-search-font: clamp(16px, 1.1vw, 28px);
        --eta-engine-font: clamp(16px, 1.0vw, 20px);
        --eta-title-font: clamp(32px, 2.2vw, 44px);
        --eta-engine-min: 72px;

        /* 横向滚动条/滑块预留：保证有无滚动条时高度一致，避免搜索区上下抖动 */
        /* --eta-hscroll-reserve: 16px; */
        /* --eta-stype-height: 48px; */
        --eta-engines-height: 60px;
    }

    /* 增大引擎类别间隔，防止文字被切断 */
    .user-bookmark-body .search-type>li {
        flex: 1 1 auto !important;
        min-width: 0 !important;
        max-width: none !important;
        /* 关键：防止第一个/最后一个被flex收缩导致内容溢出被裁切 */
        overflow: visible !important;
    }

    .user-bookmark-body .search-type li label,
    .user-bookmark-body .search-type li.menu-item {
        overflow: visible !important;
        text-overflow: initial !important;
        white-space: nowrap !important;
        flex-basis: 0 !important;
        min-width: 0 !important;
        max-width: 100%;
    }

    .user-bookmark-body .search-type li label,
    .user-bookmark-body .search-type li.menu-item {
        overflow: visible !important;
        text-overflow: initial !important;
        white-space: nowrap !important;
    }
}


/* 背景兜底 */
@media (max-width: 798px) {

    .user-bookmark-body .bookmark-bg .img-bg,
    .user-bookmark-body #img-bg {
        background-image: linear-gradient(135deg, #0f0f1e 0%, #1a1a2e 35%, #16213e 70%, #0f3460 100%);
        background-position: center center;
        background-size: auto 100%;
        background-repeat: no-repeat;
        background-attachment: fixed;
        animation: bg-img-zoom-move-narrow 20s cubic-bezier(0.4, 0.2, 0.6, 0.8) infinite alternate;
        transition: background-image 0.1s;
        z-index: 0;
    }

    @keyframes bg-img-zoom-move-narrow {
        0% {
            background-size: auto 100%;
            background-position: center 60%;
        }

        20% {
            background-size: auto 105%;
            background-position: center 55%;
        }

        35% {
            background-size: auto 110%;
            background-position: center 50%;
        }

        50% {
            background-size: auto 115%;
            background-position: center 45%;
        }

        65% {
            background-size: auto 110%;
            background-position: center 40%;
        }

        80% {
            background-size: auto 105%;
            background-position: center 35%;
        }

        100% {
            background-size: auto 100%;
            background-position: center 30%;
        }
    }
}

@media (min-width: 798.01px) {

    .user-bookmark-body .bookmark-bg .img-bg,
    .user-bookmark-body #img-bg {
        background-image: linear-gradient(135deg, #0f0f1e 0%, #1a1a2e 35%, #16213e 70%, #0f3460 100%);
        background-position: center center;
        background-size: cover;
        background-repeat: no-repeat;
        background-attachment: fixed;
        animation: bg-img-zoom-move-wide 40s cubic-bezier(0.4, 0.2, 0.6, 0.8) infinite alternate;
        transition: background-image 0.1s;
        z-index: 0;
    }

    @keyframes bg-img-zoom-move-wide {
        0% {
            background-size: 100% 100%;
            background-position: center 60%;
        }

        20% {
            background-size: 105% 105%;
            background-position: center 55%;
        }

        35% {
            background-size: 110% 110%;
            background-position: center 50%;
        }

        50% {
            background-size: 115% 115%;
            background-position: center 45%;
        }

        65% {
            background-size: 110% 110%;
            background-position: center 40%;
        }

        80% {
            background-size: 105% 105%;
            background-position: center 35%;
        }

        100% {
            background-size: 100% 100%;
            background-position: center 30%;
        }
    }
}


/* 顶部固定导航：给足高度与安全区内边距，避免左右按钮被裁切。 */
.user-bookmark-body header.navbar.fixed-top {
    left: 0;
    right: 0;
    width: 100%;
    box-sizing: border-box;
    overflow: visible;
    min-height: var(--eta-navbar-safe, 64px);
    padding-top: calc(6px + env(safe-area-inset-top));
    padding-bottom: 6px;
}

/* navbar 两侧菜单：垂直居中，且考虑安全区，避免图标只显示一半。 */
.user-bookmark-body header.navbar .navbar-menu {
    top: 0 !important;
    height: 100%;
    display: flex;
    align-items: center;
    box-sizing: border-box;
}

.user-bookmark-body header.navbar .navbar-menu[style*="left"] {
    left: calc(10px + env(safe-area-inset-left)) !important;
}

.user-bookmark-body header.navbar .navbar-menu[style*="right"] {
    right: calc(10px + env(safe-area-inset-right)) !important;
}

/* Quick sites: content is centered (60%), scrollbar is on the far right via the host. */
#sitesScrollHost {
    width: 100%;
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-gutter: stable;
    scrollbar-width: thin;
    /* thumb + transparent track (only a light thumb is visible) */
    scrollbar-color: rgba(255, 255, 255, 0.1) transparent;
    /* 让中部快捷区在固定 vh 行内滚动，而不是把整页顶开 */
    height: 100%;
}

/* Only keep a light scrollbar thumb on WebKit browsers */
#sitesScrollHost::-webkit-scrollbar {
    width: 5px;
}

#sitesScrollHost::-webkit-scrollbar-track {
    background: transparent;
}

#sitesScrollHost::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0);
    border-radius: 5px;
    border: 0.8px solid transparent;
    background-clip: content-box;
}

#sitesViewport {
    width: var(--eta-sites-width) !important;
    max-width: var(--eta-sites-width) !important;
    margin-left: auto;
    margin-right: auto;
    box-sizing: border-box;
}

/* mini 分组栏 + 卡片区布局 */
.mini-sites-layout {
    display: flex;
    align-items: stretch;
    gap: 18px;
}

/* Before JS wraps #miniGroupNav into the fixed rail, keep it out of layout flow.
   This prevents a blank left reserved column on first paint (e.g. portrait refresh). */
.mini-sites-layout>#miniGroupNav {
    display: none;
}

/* Reserve space for the fixed left group rail; keep main content centered by using symmetric padding. */
:root {
    /* rail scale is primarily for portrait mode */
    --mini-rail-scale: 1;
    --mini-group-rail-width: 54px;
    --mini-rail-gap: 18px;
    --mini-rail-extra: 10px;
    --mini-rail-reserve-left: calc(var(--mini-group-rail-width) + var(--mini-rail-gap) + var(--mini-rail-extra));
    --mini-rail-reserve-right: var(--mini-rail-reserve-left);
}

/* 默认收起：减少两侧预留空白，让内容更居中、更宽 */
:root.mini-group-rail-collapsed {
    --mini-rail-reserve-left: calc(12px + env(safe-area-inset-left, 0px));
    --mini-rail-reserve-right: calc(12px + env(safe-area-inset-right, 0px));
}

/* group rail: arrows + scrollable icons as ONE fixed unit */
.mini-group-rail {
    /* sizing model: show exactly 8 icons fully */
    --mini-group-visible-count: 8;
    --mini-group-btn-size: calc(46px * var(--mini-rail-scale));
    --mini-group-btn-gap: calc(10px * var(--mini-rail-scale));
    --mini-group-nav-pad-y: calc(10px * var(--mini-rail-scale));
    --mini-group-arrow-h: calc(34px * var(--mini-rail-scale));
    --mini-group-rail-gap: calc(8px * var(--mini-rail-scale));
    --mini-group-nav-height: calc((var(--mini-group-nav-pad-y) * 2) + (var(--mini-group-btn-size) * var(--mini-group-visible-count)) + (var(--mini-group-btn-gap) * (var(--mini-group-visible-count) - 1)));
    /* up + down + toggle 三个控制按钮 */
    --mini-group-rail-height: calc(var(--mini-group-nav-height) + (var(--mini-group-arrow-h) * 3) + (var(--mini-group-rail-gap) * 3));

    position: fixed;
    left: calc(8px + env(safe-area-inset-left, 0px));
    bottom: calc(10px + env(safe-area-inset-bottom, 0px));
    top: auto;
    transform: none;
    z-index: 1100;
    width: var(--mini-group-rail-width);
    height: var(--mini-group-rail-height);
    max-height: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--mini-group-rail-gap);
    user-select: none;
    overflow: visible;
}

/* 收起状态：隐藏图标列表，但保留“展开/收起”按钮 */
.mini-group-rail.is-collapsed {
    height: auto;
}

.mini-group-rail.is-collapsed .mini-group-nav {
    display: none;
}

.mini-group-rail.is-collapsed .mini-group-arrow:not(.mini-group-toggle) {
    display: none;
}

.mini-group-nav {
    flex: none;
    width: var(--mini-group-rail-width);
    display: flex;
    flex-direction: column;
    gap: var(--mini-group-btn-gap);
    padding: var(--mini-group-nav-pad-y) 0;
    user-select: none;
    /* now becomes the scrollable list INSIDE .mini-group-rail */
    flex: 0 0 var(--mini-group-nav-height);
    height: var(--mini-group-nav-height);
    min-height: 0;
    /* allow hover label to extend to the right, while Y scrolling is enabled by JS */
    overflow-x: visible;
    overflow-y: hidden;
    cursor: grab;
    align-items: center;
}

.mini-group-nav .mini-group-btn {
    width: var(--mini-group-btn-size);
    height: var(--mini-group-btn-size);
    border-radius: calc(14px * var(--mini-rail-scale));
    border: 1px solid rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.86);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    /* 保证图标在未展开时水平居中 */
    cursor: pointer;
    transition: transform 140ms ease, background-color 140ms ease, border-color 140ms ease, width 160ms ease;
    position: relative;
    /* 让内部 label 绝对定位，不占布局空间 */
    padding: 0;
    overflow: visible;
}

.mini-group-nav.is-dragging {
    cursor: grabbing;
}

/* always show up/down arrow hints OUTSIDE group nav (fixed, not scrolling) */
.mini-group-arrow {
    position: relative;
    width: var(--mini-group-btn-size);
    height: var(--mini-group-arrow-h);
    min-height: var(--mini-group-arrow-h);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: calc(14px * var(--mini-rail-scale));
    background: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.92);
    box-shadow: 0 10px 22px rgba(0, 0, 0, 0.22);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    cursor: pointer;
    user-select: none;
    padding: 0;
}

.mini-group-arrow:hover {
    background: rgba(255, 255, 255, 0.10);
    border-color: rgba(255, 255, 255, 0.26);
    transform: translateY(-1px);
}

.mini-group-arrow:active {
    transform: translateY(0px);
}

.mini-group-arrow svg {
    width: calc(16px * var(--mini-rail-scale));
    height: calc(16px * var(--mini-rail-scale));
}

/* 下箭头下方的折叠/展开按钮 */
.mini-group-toggle {
    position: relative;
}

.mini-group-toggle .mini-toggle-sr {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.mini-group-toggle .mini-toggle-icon {
    width: calc(19px * var(--mini-rail-scale));
    height: calc(19px * var(--mini-rail-scale));
    display: block;
}

/* 展开时让宝箱更“亮”，提示可收起 */
.mini-group-toggle.is-open {
    background: rgba(0, 34, 255, 0.18);
    border-color: rgba(0, 34, 255, 0.40);
}

.mini-group-toggle.is-open:hover {
    background: rgba(0, 34, 255, 0.24);
}

/* hide native scrollbar for group nav but keep programmatic scrolling */
.mini-group-nav {
    scrollbar-width: none;
    /* Firefox */
}

.mini-group-nav::-webkit-scrollbar {
    width: 0 !important;
    height: 0 !important;
}

.mini-group-nav .mini-group-btn:hover {
    transform: translateY(-1px);
    background: rgba(255, 255, 255, 0.10);
    border-color: rgba(255, 255, 255, 0.22);
}

.mini-group-nav .mini-group-btn.is-active {
    background: rgba(0, 34, 255, 0.22);
    border-color: rgba(0, 34, 255, 0.40);
}

.mini-group-nav .mini-group-btn i.iconfont {
    font-size: calc(20px * var(--mini-rail-scale));
    line-height: 1;
}

.mini-group-nav .mini-group-inner {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    /* 固定内层宽度，保证图标在收起时水平居中不受文字影响 */
    position: relative;
    width: var(--mini-group-btn-size);
    height: var(--mini-group-btn-size);
    justify-content: center;
}

.mini-group-nav .mini-group-btn .mini-group-label {
    /* 文字绝对定位在图标右侧，显示/隐藏仅改变透明度，不影响图标布局 */
    position: absolute;
    left: calc(var(--mini-group-btn-size) + 12px);
    top: 50%;
    transform: translateY(-50%);
    opacity: 0;
    white-space: nowrap;
    font-size: 13px;
    line-height: 1;
    transition: opacity 140ms ease 100ms;
    color: inherit;
    margin: 0;
    pointer-events: none;
    display: none;
}

.mini-group-nav .mini-group-btn:hover {
    transform: translateY(-1px);
    background: rgba(255, 255, 255, 0.10);
    border-color: rgba(255, 255, 255, 0.22);
    /* 保持按钮宽度不变，仅显示绝对定位的文字，不改变布局 */
}

/* inline labels are hidden; use the floating tooltip instead */
.mini-group-nav .mini-group-btn:hover .mini-group-label {
    opacity: 0;
}

.mini-sites-grid-wrap {
    flex: 1;
    min-width: 0;
}

/* 防止固定左侧栏遮挡快捷区内容：给滚动宿主增加左内边距 */
#sitesScrollHost {
    box-sizing: border-box;
    padding-left: var(--mini-rail-reserve-left);
    padding-right: var(--mini-rail-reserve-right);
}

/* Search area should also reserve the same space on both sides (any width) */
.user-bookmark-body .header-big {
    padding-left: var(--mini-rail-reserve-left);
    padding-right: var(--mini-rail-reserve-right);
}

/* 竖屏：预留左侧 group 图标栏空间，让搜索区与快捷区整体右移 */
@media (orientation: portrait) {

    :root {
        /* shrink the left icon rail to 60% in portrait */
        --mini-rail-scale: 0.8;
        --mini-group-rail-width: calc(54px * 0.8);

        /* do NOT reserve a symmetric right blank area in portrait */
        --mini-rail-reserve-left: calc(var(--mini-group-rail-width) + 12px + env(safe-area-inset-left, 0px));
        --mini-rail-reserve-right: calc(12px + env(safe-area-inset-right, 0px));
    }

    /* 防止竖屏下因 padding 导致横向溢出 */
    html,
    body {
        overflow-x: hidden;
    }
}

/* 小屏：分组栏改为横向，避免挤压卡片区 */
@media (max-width: 576px) {
    .mini-sites-layout {
        flex-direction: column;
        gap: 12px;
    }

    .mini-group-nav {
        /* keep left fixed layout even on narrow screens to preserve UX */
        width: var(--mini-group-rail-width);
        flex-direction: column;
        overflow-y: auto;
        padding: 6px 0;
        gap: 10px;
    }

    .mini-group-nav::-webkit-scrollbar {
        height: 6px;
    }

    .mini-group-nav::-webkit-scrollbar-track {
        background: transparent;
    }

    .mini-group-nav::-webkit-scrollbar-thumb {
        background: rgba(255, 255, 255, 0.10);
        border-radius: 8px;
    }

    /* small screens: keep content padding to avoid overlap with left group nav */
    #sitesScrollHost {
        padding-left: var(--mini-rail-reserve-left);
        padding-right: var(--mini-rail-reserve-right);
    }
}

/* Group hover tooltip (not clipped by scroll containers) */
.mini-group-tooltip {
    position: fixed;
    transform: translateY(-50%);
    padding: 8px 10px;
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(10, 12, 18, 0.42);
    color: rgba(255, 255, 255, 0.92);
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.30);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    font-size: 13px;
    line-height: 1;
    white-space: nowrap;
    pointer-events: none;
    opacity: 0;
    visibility: hidden;
    transition: opacity 120ms ease;
    z-index: 1300;
}

.mini-group-tooltip.is-visible {
    opacity: 1;
    visibility: visible;
}

/* Quick-sites card hover tooltip: centered above cursor, frosted + transparent */
.mini-sites-tooltip {
    position: fixed;
    left: 0;
    top: 0;
    transform: translate(-50%, -100%) scale(0.98);
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    background: rgba(15, 18, 26, 0.35);
    color: rgba(255, 255, 255, 0.92);
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.35);
    backdrop-filter: blur(14px) saturate(160%);
    -webkit-backdrop-filter: blur(14px) saturate(160%);
    font-size: 13px;
    font-weight: 600;
    line-height: 1.2;
    letter-spacing: 0.2px;
    white-space: nowrap;
    pointer-events: none;
    opacity: 0;
    visibility: hidden;
    transition: opacity 120ms ease, transform 120ms ease;
    z-index: 1400;
    text-shadow: 0 8px 18px rgba(0, 0, 0, 0.35);
}

.mini-sites-tooltip.is-visible {
    opacity: 1;
    visibility: visible;
    transform: translate(-50%, -100%) scale(1);
}


/* Cancel the "expand from corner" dropdown animation to save resources. */
.user-bookmark-body .navbar-menu .dropdown-menu,
.user-bookmark-body .navbar-menu .dropdown-menu.show {
    transition: none !important;
}

/* Keep search tab scroller stable: always reserve horizontal scrollbar space, but keep it small and faint.
   确保横向滚动条的出现/消失不影响整体布局高度。 */
.s-type {
    scrollbar-gutter: stable both-edges;
    scrollbar-width: thin;
    scrollbar-color: rgba(200, 200, 200, 0.25) transparent;
    box-sizing: border-box;
    /* height: var(--eta-stype-height);
    min-height: var(--eta-stype-height);
    padding-bottom: var(--eta-hscroll-reserve); */
    overflow-x: auto;
    overflow-y: visible;
    min-height: 0;
    max-width: 100%;
    width: 100%;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-x;
}

/* 搜索框下方“搜索方案”条：任意宽度下都在容器内横向滚动。
   主题 CSS 虽有 overflow:auto，但在极窄宽度下容易被布局/居中方式吞掉滚动体验；这里强制为横向滚动。 */
.user-bookmark-body .search-type {
    display: flex !important;
    flex-wrap: nowrap !important;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    box-sizing: border-box;
    height: var(--eta-engines-height);
    min-height: var(--eta-engines-height);
    width: var(--eta-search-width);
    max-width: 100%;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scrollbar-gutter: stable both-edges;
    scrollbar-width: thin;
    scrollbar-color: rgba(200, 200, 200, 0.25) transparent;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-x;
    /* padding-bottom: var(--eta-hscroll-reserve); */
    margin: 0 auto;
    padding-left: 2px;
    padding-right: 2px;
}

.user-bookmark-body .search-type>li {
    flex: 1 1 0;
    min-width: var(--eta-engine-min);
}

/* 让每个引擎项在“搜索框宽度”内均分占位，文本居中。 */
.user-bookmark-body .search-type li label,
.user-bookmark-body .search-type li.menu-item {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    text-align: center;
    white-space: nowrap;
    font-size: var(--eta-engine-font);
    overflow: hidden;
    line-height: 1.8;
}


.user-bookmark-body .search-type::-webkit-scrollbar {
    height: 8px;
}

.user-bookmark-body .search-type::-webkit-scrollbar-track {
    background: transparent;
}

.user-bookmark-body .search-type::-webkit-scrollbar-thumb {
    background: rgba(200, 200, 200, 0.25);
    border-radius: 3px;
    border: 2px solid transparent;
    background-clip: content-box;
}

.s-type::-webkit-scrollbar {
    height: 8px;
    /* 更细的横向滚动条 */
}

.s-type::-webkit-scrollbar-track {
    background: transparent;
}

.s-type::-webkit-scrollbar-thumb {
    background: rgba(200, 200, 200, 0.25);
    /* 更淡的颜色 */
    border-radius: 3px;
    border: 2px solid transparent;
    background-clip: content-box;
}

/* Theme CSS clips quick-sites to 200px; override to allow up to 3 rows + scroll. */
.quick-sites .row,
.quick-sites #sitesContainer {
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
}

/*
  Auto layout inside the centered 60% viewport:
  Use CSS Grid so the number of items per row flexes with the available width,
  and keep horizontal/vertical spacing consistent via `gap`.
*/
.quick-sites #sitesContainer {
    --site-gap: 55px;
    /* 左右/上下间距（越大 → 更疏朗）*/
    --site-min: 100px;
    /* 最小图标宽度（越大 → 每行越少图标）*/
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(var(--site-min), 1fr));
    gap: var(--site-gap);
    align-items: start;
    justify-items: center;
    padding: 8px 0;
}

/* Override Bootstrap/theme sizing on the tile so gap is the only spacing source. */
.quick-sites .sites-btn {
    flex: none !important;
    width: 100% !important;
    max-width: none !important;
    padding: 0 !important;
    margin: 0 !important;
    margin-bottom: 0 !important;
    /* overrides mb-4 */
}


.sites-btn {
    position: relative;
    transition: all 0.3s;
    margin-bottom: 15px;
    /* 增加底部间距，确保有足够空间显示多行 */
}

.sites-btn.edit-mode {
    cursor: move;
    border: none;
}

.sites-icon {
    position: relative;
}

/* Ensure site icons render with their original colors. */
#sitesContainer .sites-icon img,
.quick-sites .sites-icon img {
    filter: none !important;
    -webkit-filter: none !important;
    opacity: 1 !important;
    mix-blend-mode: normal;
}

.sites-icon:hover .site-controls-top {
    display: flex;
    /* 鼠标悬停时显示按钮 */
}

.site-controls {
    position: absolute;
    bottom: 5px;
    left: 0;
    right: 0;
    text-align: center;
    z-index: 1010;
    /* 提高z-index确保按钮不被遮挡 */
}

.site-controls-top {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1020;
    /* 更高的z-index确保按钮显示在最上层 */
    bottom: auto;
    display: none;
    /* 默认隐藏 */
    flex-direction: row;
    justify-content: center;
    align-items: center;
    gap: 5px;
    /* 确保按钮垂直居中 */
    height: 100%;
    width: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    /* 半透明背景，提高按钮可见度 */
}

.site-controls button {
    margin: 0 2px;
    padding: 2px 5px;
    font-size: 12px;
    border-radius: 3px;
    transition: all 0.2s ease;
}

/* 拖拽时的样式 */
.site-ghost {
    opacity: 0.5;
    background: rgba(0, 123, 255, 0.2);
}

.site-chosen {
    background: rgba(0, 123, 255, 0.2);
}

/* 顶部编辑按钮样式 */
.nav-login .btn {
    padding: 0.25rem 0.5rem;
    font-size: 0.875rem;
    line-height: 1.5;
    border-radius: 0.2rem;
    color: #fff;
    background-color: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
}

/* 确保上传按钮与其他按钮在同一水平线上 */
.nav-login label.btn {
    display: inline-block;
    /* 使按钮成为块级元素，确保正确的布局行为 */
    vertical-align: middle;
    /* 使按钮垂直居中 */
    margin-bottom: 0;
    /* 消除可能的底部间距 */
}

.nav-login .btn:hover {
    background-color: rgba(255, 255, 255, 0.2);
    border-color: rgba(255, 255, 255, 0.3);
}

.nav-login .btn i {
    font-size: 1em;
}

/* 调整按钮间距 */
.nav-login .ml-1 {
    margin-left: 0.25rem !important;
}

.nav-login .ml-3 {
    margin-left: 1rem !important;
}

/* 编辑对话框样式 */
.site-edit-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.7);
    z-index: 2000;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    padding-top: 50px;
}

.site-edit-modal-content {
    background-color: #222;
    border-radius: 8px;
    width: 80%;
    max-width: 800px;
    max-height: 80vh;
    overflow-y: auto;
    color: #fff;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5);
    border: 1px solid rgba(255, 255, 255, 0.2);
}

.site-edit-modal-header {
    padding: 15px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.site-edit-modal-body {
    padding: 15px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.site-edit-modal-footer {
    padding: 10px;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    text-align: right;
}

.close-modal {
    color: #aaa;
    font-size: 28px;
    font-weight: bold;
    cursor: pointer;
}

.close-modal:hover {
    color: #fff;
}

.form-group {
    margin-bottom: 15px;
}

.form-group label {
    display: block;
    margin-bottom: 5px;
}

.form-control {
    width: 100%;
    padding: 8px;
    background-color: #333;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 4px;
    color: #fff;
}

/* 确保标签页预览区域中的所有标签都能显示 */
.existing-sites-container {
    max-height: 350px;
    overflow-y: auto;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 10px;
}

/* 确保编辑按钮在所有标签页上都能正常显示 */
.existing-sites-container .site-item {
    position: relative;
}

.existing-sites-container .site-item .edit-btn,
.existing-sites-container .site-item .delete-btn {
    position: absolute;
    z-index: 1010;
    /* 提高z-index确保按钮不被遮挡 */
    display: block;
    top: 5px;
}

.existing-sites-container .site-item .edit-btn {
    right: 25px;
}

.existing-sites-container .site-item .delete-btn {
    right: 5px;
}

/* 确保标签页内容不会被编辑按钮遮挡 */
.existing-sites-container .site-item .site-content {
    padding-top: 10px;
}

.existing-site-item {
    background-color: rgba(255, 255, 255, 0.1);
    border-radius: 4px;
    padding: 8px;
    cursor: pointer;
    transition: all 0.3s;
    display: flex;
    align-items: center;
    gap: 8px;
}

.existing-site-item:hover {
    background-color: rgba(255, 255, 255, 0.2);
}

.existing-site-item img {
    width: 20px;
    height: 20px;
    border-radius: 3px;
}

/* 1.5列布局样式 */
.col-lg-1-5 {
    flex: 0 0 12.5%;
    max-width: 12.5%;
}


/* 调整容器最大宽度和边距 */
.container-md.px-5 {
    max-width: 85% !important;
    padding-left: 1rem !important;
    padding-right: 1rem !important;
}

/* mini：站点卡片图标统一用“正方形占位 + contain 不裁切” */
:root {
    --mini-site-icon-box: 30px;
}

@media (orientation: portrait) {
    :root {
        --mini-site-icon-box: 28px;
    }
}

.sites-icon {
    width: var(--mini-site-icon-box);
    height: var(--mini-site-icon-box);
    aspect-ratio: 1 / 1;
    box-sizing: border-box;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

/* 图片图标：以正方形盒为约束，不裁切内容 */
.sites-icon img {
    width: 100%;
    height: 100%;
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    display: block;
}

/* 字体图标 / emoji：也限制在同一正方形区域内 */
.sites-icon i,
.sites-icon .mini-site-emoji {
    font-size: calc(var(--mini-site-icon-box) * 0.76);
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.sites-icon.is-font-icon i,
.sites-icon.is-font-icon .mini-site-emoji {
    transform: none;
}

/* 卡片图标（仅图标库 i）：默认紫色，悬浮红色；emoji 保留原色 */
.sites-icon.is-font-icon i {
    color: #38892a;
}

.sites-btn:hover .sites-icon.is-font-icon i {
    color: #dc3545;
}

/* mini：图标下方文字不显示省略号（..）。超出宽度直接裁切。 */
#sitesContainer .sites-title.overflowClip_1,
#sitesContainer .sites-title.overflowClip_1 span {
    text-overflow: clip !important;
    -o-text-overflow: clip !important;
}

/* 搜索方案 tab：在任意宽度下都走“区域内横向滚动”，不影响页面整体宽度。
   覆盖主题可能存在的 absolute/固定宽度写法，避免小屏出现布局挤压或需要拖动整页。 */
.user-bookmark-body .s-type {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    width: 100% !important;
}


.user-bookmark-body {
    --eta-after-title-shift: 0vh;
}

.user-bookmark-body .page-container {
    min-height: 100vh !important;
    display: grid !important;
    grid-template-rows: var(--eta-header-vh) var(--eta-sites-vh) var(--eta-footer-vh) !important;
    width: 100%;
    max-width: 100vw;
    overflow-x: hidden;
}

.user-bookmark-body .header-big {
    margin-top: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    height: 100%;
    min-height: 0 !important;
    display: flex;
    flex-direction: column;
    justify-content: center;
    grid-row: 1;

    /* 预留固定导航高度，避免顶部按钮覆盖搜索区 */
    padding-top: var(--eta-navbar-safe) !important;
    padding-bottom: 1vh !important;
    box-sizing: border-box;
    font-size: var(--eta-search-font);
}

.user-bookmark-body .eta-search-below-title {
    padding-top: var(--eta-after-title-shift);
}

.user-bookmark-body .quick-sites {
    margin-top: 0 !important;
    height: 100%;
    min-height: 0;
    grid-row: 2;
}

.user-bookmark-body footer.main-footer {
    margin-top: auto !important;
    grid-row: 3;
    height: 100%;
    padding-top: 0 !important;
    padding-bottom: var(--eta-footer-bottom-gap) !important;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    box-sizing: border-box;
}

.user-bookmark-body footer.main-footer .footer-inner {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding-top: 0 !important;
    padding-bottom: var(--eta-footer-bottom-gap) !important;
}

/* 取消 header 背景的左右渐变动画（通过 .header-big.css-color + @keyframes gradient 实现 */
.header-big.css-color {
    -webkit-animation: none !important;
    animation: none !important;
    background-position: center center !important;
    background-size: auto !important;
}

/* 确保搜索框及其 placeholder 不应用任何额外动画/渐变效果。 */
.super-search-fm .search-key,
.super-search-fm .search-key::placeholder {
    animation: none !important;
    -webkit-animation: none !important;
    transition: none !important;
    background-image: none !important;
}

.super-search-fm .search-key::placeholder {
    color: #bbb;
    opacity: 1;
}

/* 标题与输入框字号随宽度变化（窄屏更紧凑，宽屏更舒展）。 */

/* --- Ultra-short height: hide shortcuts + group rail + edit controls --- */
@media (max-height: 499px) {
    :root {
        /* Collapse the shortcuts row entirely to avoid blank grid space. */
        --eta-header-vh: calc(70vh);
        --eta-sites-vh: 0vh;
        /* 隐藏快捷方式区 */
        --eta-footer-vh: calc(30vh);
    }

    /* Hide the whole shortcuts section (cards + left group rail). */
    .user-bookmark-body .quick-sites {
        display: none !important;
    }

    /* Redundant safety: group rail/nav should never appear in short viewports. */
    #miniGroupNav,
    .mini-group-nav {
        display: none !important;
    }

    /* Hide group-mini edit module (top-left buttons) even if JS toggles them. */
    #editSitesBtn,
    #cancelEditBtn,
    #addSiteBtn,
    #saveSitesBtn,
    #resetSitesBtn,
    #exportConfigBtn,
    label[for="importConfigInput"],
    #importConfigInput {
        display: none !important;
    }

    /* Prevent the edit modal from showing in this constrained layout. */
    #siteEditModal {
        display: none !important;
    }
}

.user-bookmark-body .big-title .h1 {
    font-size: var(--eta-title-font) !important;
}

.user-bookmark-body .super-search-fm .search-key {
    font-size: var(--eta-search-font);
}

/* 搜索框整体宽度与内容宽度一致（与 #sitesViewport 对齐）。 */
.user-bookmark-body .header-big .s-search,
.user-bookmark-body #search {
    width: var(--eta-search-width);
    max-width: var(--eta-search-width);
    margin-left: auto;
    margin-right: auto;
    box-sizing: border-box;
}

.user-bookmark-body .super-search-fm {
    width: 100% !important;
    max-width: 100% !important;
}

/* Mini：All 复选框放在输入框外侧左边（同一行） */
.user-bookmark-body .super-search-fm {
    display: flex;
    align-items: stretch;
    gap: 0;
}

.user-bookmark-body .super-search-fm .eta-search-all {
    flex: 0 0 auto;
    height: 50px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 0 14px;
    border-radius: 3px 0 0 3px;
    background-color: #0a0a0c79;
    border: none !important;
    border-right: none !important;
    color: rgba(255, 255, 255, 0.72);
    user-select: none;
    white-space: nowrap;
    cursor: pointer;
    transition: background-color .3s, color .3s, height .25s cubic-bezier(0.4, 0, 0.2, 1);
}

.user-bookmark-body .super-search-fm .eta-search-all:hover {
    background-color: rgba(0, 0, 0, 0.035);
    color: rgba(255, 255, 255, 0.8);
}

.user-bookmark-body .super-search-fm .eta-search-all:active {
    background-color: rgba(0, 0, 0, 0.055);
}

.user-bookmark-body .super-search-fm .eta-search-all input {
    width: 16px;
    height: 16px;
    margin: 0;
    accent-color: #313437;
}

.user-bookmark-body .super-search-fm .eta-search-all span {
    font-size: 14px;
    line-height: 1;
    font-weight: 600;
    letter-spacing: 0.2px;
}

.user-bookmark-body .super-search-fm .search-key {
    flex: 1 1 auto;
    min-width: 0;
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

/* mini：覆盖主题的 .header-big #search-text（ 25px 圆角），让左侧为直角并与 All 连接，右侧圆角对齐主页 */
.user-bookmark-body .header-big #search-text {
    border-top-left-radius: 0 !important;
    /* 左侧直角 */
    border-bottom-left-radius: 0 !important;
    border-top-right-radius: 25px !important;
    /* 右侧圆角 */
    border-bottom-right-radius: 25px !important;
}

/* mini：夜间模式对齐主题搜索框暗底 */
.io-black-mode .user-bookmark-body .super-search-fm .eta-search-all {
    background-color: #0a0a0c79;
    border-right-color: rgba(255, 255, 255, 0.10);
    color: rgba(255, 255, 255, 0.78);
}

.io-black-mode .user-bookmark-body .super-search-fm .eta-search-all:hover {
    background-color: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.86);
}

.io-black-mode .user-bookmark-body .super-search-fm .eta-search-all input {
    accent-color: #fff;
}

/* --- Ported Search Box Functionality (from Main Index) --- */


.s-search .search-type {
    overflow-x: auto;
    overflow-y: hidden;
}


.header-big #search {
    width: 75%;
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
}

.header-big .s-search {
    --eta-category-font: clamp(16px, 1.15vw, 22px);
    /* 类别文字字号 */
    --eta-engine-font: clamp(14px, 1.05vw, 20px);
    --eta-engine-min: 72px;
    --eta-engines-height: 48px;
    --eta-scrollbar-height: 18px;
}

.header-big .s-search #search-list-menu .s-type-list.big>label {
    font-size: var(--eta-category-font);
    line-height: 1.1;
}

.header-big .s-search #search-list {
    display: block !important;
}

.header-big .s-search #search-list .search-group {
    padding-left: 0;
}


.header-big .s-search #search-list .search-type {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    box-sizing: border-box;
    height: var(--eta-engines-height);
    min-height: var(--eta-engines-height);
    width: 100%;
    margin: 0;
    padding-left: 2px;
    padding-right: 2px;
    white-space: nowrap;

    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-x;
    scrollbar-width: none;
}

.header-big .s-search #search-list .search-type::-webkit-scrollbar {
    height: 0;
}

.header-big #search .super-search-fm .eta-search-all {
    border: none !important;
    border-right: none !important;
    height: 49px !important;
    display: flex;
    align-items: center;
    box-sizing: border-box;
}

@media (max-width: 767.98px) {
    .header-big #search .super-search-fm .eta-search-all {
        height: 28px !important;
        min-height: 28px !important;
        border: none !important;
        /* 保证与输入框高度同步 */
        box-sizing: border-box;
    }

    .user-bookmark-body .super-search-fm .eta-search-all {
        height: 28px !important;
        min-height: 28px !important;
        box-sizing: border-box;
    }
}

/* Activated / Double Click Highlight */
.header-big .s-search #search-list .search-type li.activated label span {
    color: #ffff00 !important;
    font-weight: 700;
}

.io-black-mode .header-big .s-search #search-list .search-type li.activated label span {
    color: #00ffc8 !important;
}

/* 当搜索输入框获得焦点时：立即隐藏底下快捷方式区。
   JS 会在 blur 时触发一次 resize，从而保留原有“按页面高度/布局重算”逻辑。 */
html.mini-search-input-focused .user-bookmark-body .quick-sites {
    display: none !important;
}