/* =====================================================================
   OpenClaw Design System v2 (Sample D · A 密度 + C 色彩)
   ---------------------------------------------------------------------
   - 兼容旧 token 名（--bg-primary / --bg-card / --text-primary ...），
     旧组件无需逐个改样式即可继承新视觉。
   - 新增 token 别名（--surface / --fg / --muted / --accent-soft ...），
     供新组件（.check / .switch / .multiselect / .tbl ...）使用。
   - 默认跟随系统 prefers-color-scheme，用户手动切换写入 localStorage。
   ===================================================================== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ----- Light theme (默认) ----- */
:root {
    /* ══════ 果味汽水 · Fruit Soda (浅色) ══════ */
    --bg-primary:    #fffbf5;
    --bg-secondary:  #fff7ed;
    --bg-card:       #ffffff;
    --bg-hover:      #fef3c7;
    --bg-input:      #ffffff;
    --border:        #f0e8dd;
    --border-light:  #e5d5c0;

    --text-primary:   #1c1917;
    --text-secondary: #44403c;
    --text-muted:     #78716c;

    --accent:        #f97316;
    --accent-hover:  #ea580c;
    --accent-dim:    rgba(249, 115, 22, 0.12);
    --accent-glow:   rgba(249, 115, 22, 0.22);

    --green:  #10b981;  --green-dim:  rgba(16, 185, 129, 0.12);
    --yellow: #eab308;  --yellow-dim: rgba(234, 179, 8, 0.12);
    --red:    #ef4444;  --red-dim:    rgba(239, 68, 68, 0.12);
    --blue:   #06b6d4;  --blue-dim:   rgba(6, 182, 212, 0.12);
    --purple: #8b5cf6;  --purple-dim: rgba(139, 92, 246, 0.12);
    --orange: #f97316;  --orange-dim: rgba(249, 115, 22, 0.12);

    --surface:        var(--bg-card);
    --surface-2:      var(--bg-secondary);
    --hover:          var(--bg-hover);
    --border-strong:  var(--border-light);
    --fg:             var(--text-primary);
    --fg-2:           var(--text-secondary);
    --muted:          var(--text-muted);
    --muted-2:        #a8a29e;
    --accent-fg:      #ffffff;
    --accent-soft:    #fff7ed;
    --rose:           #f43f5e;
    --rose-soft:      #ffe4ec;
    --amber:          var(--yellow);
    --amber-soft:     #fef9c3;
    --green-soft:     #d1fae5;
    --blue-soft:      #cffafe;
    --red-soft:       #fee2e2;
    --purple-soft:    #ede0ff;

    --sidebar-w: 248px;
    --topbar-h:  58px;
    --radius:     14px;
    --radius-sm:  10px;
    --radius-lg:  18px;
    --shadow-sm:  0 1px 2px rgba(249,115,22,.06);
    --shadow:     0 4px 14px rgba(249,115,22,.08);
    --shadow-lg:  0 12px 40px rgba(249,115,22,.12);
    --transition: 0.18s cubic-bezier(0.4, 0, 0.2, 1);

    /* 多色拼接 token */
    --accent-2:      #06b6d4;
    --accent-2-dim:  rgba(6, 182, 212, 0.12);
    --accent-3:      #ec4899;
    --accent-3-dim:  rgba(236, 72, 153, 0.12);
    --accent-4:      #8b5cf6;
    --accent-4-dim:  rgba(139, 92, 246, 0.12);
    --accent-5:      #eab308;
    --accent-5-dim:  rgba(234, 179, 8, 0.12);

    color-scheme: light;
}

/* ----- Dark theme（手动切换 / 系统偏好） ----- */
:root[data-theme="dark"] {
    /* ══════ 果味汽水 · Fruit Soda (深色) ══════ */
    --bg-primary:    #1c1917;
    --bg-secondary:  #282420;
    --bg-card:       #282420;
    --bg-hover:      #3d3730;
    --bg-input:      #282420;
    --border:        #3d3730;
    --border-light:  #57534e;

    --text-primary:   #f5f0eb;
    --text-secondary: #d6d0c8;
    --text-muted:     #a8a098;

    --accent:        #fb923c;
    --accent-hover:  #fdba74;
    --accent-dim:    rgba(251, 146, 60, 0.16);
    --accent-glow:   rgba(251, 146, 60, 0.30);

    --green:  #34d399;  --green-dim:  rgba(52, 211, 153, 0.14);
    --yellow: #facc15;  --yellow-dim: rgba(250, 204, 21, 0.14);
    --red:    #fb7185;  --red-dim:    rgba(251, 113, 133, 0.14);
    --blue:   #22d3ee;  --blue-dim:   rgba(34, 211, 238, 0.14);
    --purple: #c4b5fd;  --purple-dim: rgba(196, 181, 253, 0.14);
    --orange: #fb923c;  --orange-dim: rgba(251, 146, 60, 0.14);

    --muted-2:        #78716c;
    --accent-soft:    rgba(251, 146, 60, 0.16);
    --rose:           #fb7185;
    --rose-soft:      rgba(251, 113, 133, 0.14);
    --amber-soft:     rgba(250, 204, 21, 0.14);
    --green-soft:     rgba(52, 211, 153, 0.14);
    --blue-soft:      rgba(34, 211, 238, 0.14);
    --red-soft:       rgba(251, 113, 133, 0.14);
    --purple-soft:    rgba(196, 181, 253, 0.14);

    /* 多色拼接 token (深色) */
    --accent-2:      #22d3ee;
    --accent-2-dim:  rgba(34, 211, 238, 0.14);
    --accent-3:      #f472b6;
    --accent-3-dim:  rgba(244, 114, 182, 0.14);
    --accent-4:      #c4b5fd;
    --accent-4-dim:  rgba(196, 181, 253, 0.14);
    --accent-5:      #facc15;
    --accent-5-dim:  rgba(250, 204, 21, 0.14);

    --shadow-sm:  0 1px 2px rgba(0,0,0,.5);
    --shadow:     0 4px 14px rgba(0,0,0,.5);
    --shadow-lg:  0 14px 44px rgba(0,0,0,.65);

    color-scheme: dark;
}

/* 系统偏好默认值（仅当未手动设置 data-theme 时生效） */
@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]):not([data-theme="dark"]) {
        --bg-primary:    #1c1917;
        --bg-secondary:  #282420;
        --bg-card:       #282420;
        --bg-hover:      #3d3730;
        --bg-input:      #282420;
        --border:        #3d3730;
        --border-light:  #57534e;
        --text-primary:   #f5f0eb;
        --text-secondary: #d6d0c8;
        --text-muted:     #a8a098;
        --accent:        #fb923c;
        --accent-hover:  #fdba74;
        --accent-dim:    rgba(251, 146, 60, 0.16);
        --accent-glow:   rgba(251, 146, 60, 0.30);
        --green:  #34d399;  --green-dim:  rgba(52, 211, 153, 0.14);
        --yellow: #facc15;  --yellow-dim: rgba(250, 204, 21, 0.14);
        --red:    #fb7185;  --red-dim:    rgba(251, 113, 133, 0.14);
        --blue:   #22d3ee;  --blue-dim:   rgba(34, 211, 238, 0.14);
        --purple: #c4b5fd;  --purple-dim: rgba(196, 181, 253, 0.14);
        --orange: #fb923c;  --orange-dim: rgba(251, 146, 60, 0.14);
        --muted-2:        #78716c;
        --accent-soft:    rgba(251, 146, 60, 0.16);
        --rose:           #fb7185;
        --rose-soft:      rgba(251, 113, 133, 0.14);
        --amber-soft:     rgba(250, 204, 21, 0.14);
        --green-soft:     rgba(52, 211, 153, 0.14);
        --blue-soft:      rgba(34, 211, 238, 0.14);
        --red-soft:       rgba(251, 113, 133, 0.14);
        --purple-soft:    rgba(196, 181, 253, 0.14);
        --shadow-sm:  0 1px 2px rgba(0,0,0,.5);
        --shadow:     0 4px 14px rgba(0,0,0,.5);
        --shadow-lg:  0 14px 44px rgba(0,0,0,.65);
        color-scheme: dark;
    }
}

html { font-size: 14px; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body {
    font-family: 'Inter Tight', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang SC',
                 'Microsoft YaHei', sans-serif;
    background: var(--bg-primary);
    color: var(--text-primary);
    line-height: 1.55;
    letter-spacing: -0.005em;
    transition: background 0.18s ease, color 0.18s ease;
}

a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-hover); }

/* 衬线 display 字体（用于大标题，C 风灵魂） */
.display, .serif {
    font-family: 'EB Garamond', 'Georgia', 'Songti SC', 'SimSun', serif;
    font-feature-settings: 'liga' 1;
}
.mono, code, kbd, samp, pre {
    font-family: 'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, Consolas, monospace;
}

/* ===== Layout ===== */
.app-layout {
    display: flex;
    min-height: 100vh;
}

/* ===== Sidebar ===== */
.sidebar {
    width: var(--sidebar-w);
    background: var(--bg-secondary);
    border-right: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    z-index: 100;
    overflow-y: auto;
    overflow-x: hidden;
}

.sidebar-header {
    padding: 22px 20px 18px;
    border-bottom: 1px solid var(--border);
}

.logo {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 1.25rem;
    font-weight: 700;
    letter-spacing: -0.015em;
    transition: opacity var(--transition);
}
.logo:hover { opacity: .85; }

.logo-icon { font-size: 1.6rem; }
.logo-mark {
    width: 28px;
    height: 28px;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    box-shadow: 0 2px 6px var(--accent-glow);
}
.logo-mark svg { width: 28px; height: 28px; display: block; }
.logo-text {
    font-family: 'EB Garamond', Georgia, serif;
    font-weight: 600;
    font-size: 1.35rem;
    letter-spacing: -0.01em;
}
.logo-subtitle {
    font-size: 0.72rem;
    color: var(--text-muted);
    margin-top: 6px;
    letter-spacing: 0.04em;
    padding-left: 38px;
}

.sidebar-nav {
    flex: 1;
    padding: 12px 10px;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.nav-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 14px;
    border-radius: 8px;
    color: var(--text-secondary);
    font-size: 0.9rem;
    font-weight: 500;
    transition: all var(--transition);
    position: relative;
}

.nav-item:hover {
    background: var(--bg-hover);
    color: var(--text-primary);
}

.nav-item.active {
    background: var(--accent-dim);
    color: var(--accent);
    font-weight: 600;
}

.nav-item.active::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
    height: 18px;
    background: var(--accent);
    border-radius: 0 3px 3px 0;
}

.nav-icon {
    font-size: 1.1rem;
    width: 22px;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--text-muted);
    transition: color var(--transition);
}
.nav-icon svg { width: 16px; height: 16px; stroke-width: 2; }
.nav-item:hover .nav-icon { opacity: 1; color: var(--text-secondary); }
.nav-item.active .nav-icon { opacity: 1; }
.nav-group-title .nav-icon { width: 18px; opacity: 0.8; }
.nav-group-title .nav-icon svg { width: 14px; height: 14px; }
.nav-group-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex: 1;
    min-width: 0;
}

/* Nav Group (折叠菜单) */
.nav-group { margin-top: 4px; }
.nav-group-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 14px;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--text-muted);
    cursor: pointer;
    border-radius: var(--radius-sm);
    transition: all .15s;
    user-select: none;
}
.nav-group-title:hover { color: var(--text-primary); background: var(--bg-hover); }
.nav-group-arrow {
    font-size: 1rem;
    transition: transform .2s;
    display: inline-block;
}
.nav-group.open .nav-group-arrow { transform: rotate(90deg); }
.nav-group-items {
    max-height: 0;
    overflow: hidden;
    transition: max-height .25s ease;
}
.nav-group.open .nav-group-items { max-height: 500px; }
.nav-item.nav-sub {
    padding: 7px 14px 7px 28px;
    font-size: 0.85rem;
}
.nav-item.nav-sub .nav-icon { font-size: 1rem; width: 18px; }
.nav-item.nav-sub .nav-icon svg { width: 15px; height: 15px; }

.sidebar-footer {
    padding: 12px 20px;
    border-top: 1px solid var(--border);
}

.version {
    font-size: 0.75rem;
    color: var(--text-muted);
}

/* ===== Main Content ===== */
.main-content {
    flex: 1;
    margin-left: var(--sidebar-w);
    display: flex;
    flex-direction: column;
    animation: fadeIn 0.15s ease;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.top-bar {
    min-height: var(--topbar-h);
    padding: 0 28px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    border-bottom: 1px solid var(--border);
    background: var(--bg-secondary);
    backdrop-filter: blur(12px);
    position: sticky;
    top: 0;
    z-index: 50;
}

.page-title {
    font-size: 1.15rem;
    font-weight: 600;
    white-space: nowrap;
    flex-shrink: 0;
    letter-spacing: -0.01em;
}

.top-bar-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
    position: relative;
    z-index: 51;
}

.content-area {
    padding: 24px 28px;
    flex: 1;
}

/* ===== Cards ===== */
.card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px;
    transition: border-color var(--transition), box-shadow var(--transition);
}

.card:hover {
    border-color: var(--border-light);
}

.card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}

.card-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
}

/* ===== Stats Grid ===== */
/* Dashboard 紧凑统计条 */
.dash-stats-bar {
    display: flex;
    gap: 10px;
    margin-bottom: 10px;
    flex-wrap: wrap;
}
.dash-stats-bar.secondary { margin-bottom: 16px; }
.dash-stat {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 8px 16px;
    transition: border-color var(--transition);
}
.dash-stat:hover { border-color: var(--border-light); }
.dash-stat-val {
    font-size: 1.1rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.02em;
}
.dash-stat-lbl {
    font-size: 0.72rem;
    color: var(--text-muted);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.dash-stat.green .dash-stat-val { color: var(--green); }
.dash-stat.blue .dash-stat-val { color: var(--blue); }
.dash-stat.accent .dash-stat-val { color: var(--accent); }
.dash-stat.yellow .dash-stat-val { color: var(--yellow); }

.dashboard-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    background: none;
    margin-bottom: 16px;
}

.quick-stats {
    display: flex;
    gap: 16px;
    margin-bottom: 24px;
    flex-wrap: wrap;
}

.quick-stat-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 99px;
    font-size: 0.82rem;
    color: var(--text-secondary);
}

.quick-stat-icon { font-size: 1rem; }
.quick-stat-text strong { color: var(--text-primary); }

/* Dashboard 页签 */
.dashboard-tab {
    background: none; border: none;
    padding: 10px 20px; font-size: 0.88rem; font-weight: 600;
    color: var(--text-muted); cursor: pointer;
    border-bottom: 2px solid transparent; margin-bottom: -2px;
    transition: all .2s;
}
.dashboard-tab:hover { color: var(--text-primary); }
.dashboard-tab.active {
    color: var(--accent);
    border-bottom-color: var(--accent);
}
.dashboard-tabs-section { margin-top: 24px; }
.dashboard-subtab {
    background: none; border: none;
    padding: 8px 16px; font-size: 0.82rem; font-weight: 500;
    color: var(--text-muted); cursor: pointer;
    border-bottom: 2px solid transparent; margin-bottom: -1px;
    transition: all .2s;
}
.dashboard-subtab:hover { color: var(--text-primary); }
.dashboard-subtab.active {
    color: var(--accent);
    border-bottom-color: var(--accent);
}

.quick-links {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 12px;
}

.quick-link-icon { font-size: 1.6rem; }
.quick-link-label {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--text-primary);
}

.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}

.stat-value {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.03em;
}

.stat-label {
    font-size: 0.82rem;
    color: var(--text-secondary);
}

.stat-card.accent .stat-value { color: var(--accent); }
.stat-card.green .stat-value { color: var(--green); }
.stat-card.yellow .stat-value { color: var(--yellow); }
.stat-card.blue .stat-value { color: var(--blue); }

/* ===== Claw Cards ===== */
.claw-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}

.claw-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px;
    transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
    cursor: pointer;
    position: relative;
}

.claw-card:hover,
.claw-card.focused {
    border-color: var(--accent);
    box-shadow: 0 0 0 1px var(--accent-glow), 0 4px 16px rgba(0,0,0,0.2);
}

.claw-card:hover {
    transform: translateY(-2px);
}

.claw-card.focused {
    border-color: var(--accent);
    box-shadow: 0 0 0 1px var(--accent-glow), 0 4px 16px rgba(91, 95, 240, 0.15);
}

.claw-card-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
}

.claw-avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--accent-dim);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    flex-shrink: 0;
}

.claw-info { flex: 1; min-width: 0; }

.claw-name {
    font-weight: 600;
    font-size: 1.05rem;
    display: flex;
    align-items: center;
    gap: 8px;
}

.claw-role {
    font-size: 0.82rem;
    color: var(--text-secondary);
    margin-top: 1px;
}

.claw-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
}

.claw-summary {
    font-size: 0.85rem;
    color: var(--text-secondary);
    line-height: 1.5;
}

/* ===== Tags / Badges ===== */
.tag {
    display: inline-flex;
    align-items: center;
    padding: 2px 10px;
    border-radius: 99px;
    font-size: 0.78rem;
    font-weight: 500;
    gap: 4px;
    letter-spacing: 0.01em;
}

.tag-accent { background: var(--accent-dim); color: var(--accent); }
.tag-green { background: var(--green-dim); color: var(--green); }
.tag-yellow { background: var(--yellow-dim); color: var(--yellow); }
.tag-red { background: var(--red-dim); color: var(--red); }
.tag-blue { background: var(--blue-dim); color: var(--blue); }
.tag-purple { background: var(--purple-dim); color: var(--purple); }
.tag-orange { background: var(--orange-dim); color: var(--orange); }

.status-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}

/* ===== Buttons ===== */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border: none;
    border-radius: 8px;
    font-size: 0.88rem;
    font-weight: 500;
    cursor: pointer;
    transition: all var(--transition);
    font-family: inherit;
}

.btn-primary {
    background: var(--accent);
    color: var(--accent-fg, #fff);
    box-shadow: 0 1px 2px var(--accent-glow);
}
.btn-primary:hover {
    background: var(--accent-hover);
    box-shadow: 0 4px 12px var(--accent-glow);
    transform: translateY(-1px);
}
.btn-primary:active {
    transform: translateY(0);
    box-shadow: 0 1px 2px var(--accent-glow);
}

.btn-ghost, .btn-secondary {
    background: var(--bg-card);
    color: var(--text-primary);
    border: 1px solid var(--border);
}
.btn-ghost:hover, .btn-secondary:hover {
    background: var(--bg-hover);
    border-color: var(--border-light);
}

.btn-danger {
    background: var(--red-dim);
    color: var(--red);
    border: 1px solid transparent;
}
.btn-danger:hover {
    background: var(--red);
    color: #fff;
    box-shadow: 0 2px 8px var(--red-dim);
}

.btn-success {
    background: rgba(16, 185, 129, 0.12);
    color: #10b981;
    border: 1px solid transparent;
}
.btn-success:hover {
    background: #10b981;
    color: #fff;
    box-shadow: 0 2px 8px rgba(16, 185, 129, 0.25);
}

.btn-info {
    background: rgba(59, 130, 246, 0.12);
    color: #3b82f6;
    border: 1px solid transparent;
}
.btn-info:hover {
    background: #3b82f6;
    color: #fff;
    box-shadow: 0 2px 8px rgba(59, 130, 246, 0.25);
}

.btn-sm { padding: 5px 12px; font-size: 0.82rem; border-radius: 6px; }
.btn-xs { padding: 2px 8px; font-size: 0.68rem; border-radius: 5px; cursor:pointer; border:1px solid var(--border); background:var(--bg-input); color:var(--text-secondary); font-family:inherit; white-space:nowrap }
.btn-xs:hover { background:var(--bg-hover); color:var(--text-primary) }
.btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.btn:disabled, .btn[disabled] { opacity: .5; cursor: not-allowed; transform: none !important; box-shadow: none !important; }

/* ===== Forms ===== */
.form-group {
    margin-bottom: 16px;
}

.form-label {
    display: block;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--text-secondary);
    margin-bottom: 6px;
    letter-spacing: 0.02em;
}

.form-input, .form-select, .form-textarea {
    width: 100%;
    padding: 9px 12px;
    background: var(--bg-input);
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--text-primary);
    font-size: 0.9rem;
    font-family: inherit;
    outline: none;
    transition: border-color var(--transition), box-shadow var(--transition);
}

.form-input:focus, .form-select:focus, .form-textarea:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-dim);
}

.top-bar-actions .form-select,
.top-bar-actions .form-input {
    width: auto;
}

.form-textarea {
    resize: vertical;
    min-height: 80px;
    font-family: inherit;
}

/* ===== Modal ===== */
.modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(20, 18, 14, 0.42);
    backdrop-filter: blur(6px) saturate(1.1);
    -webkit-backdrop-filter: blur(6px) saturate(1.1);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 200;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s;
}

.modal-overlay.active {
    opacity: 1;
    pointer-events: auto;
}

.modal {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 24px;
    width: 90%;
    max-width: 520px;
    max-height: 85vh;
    overflow-y: auto;
    box-shadow: var(--shadow-lg);
    transform: translateY(20px) scale(0.97);
    transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: var(--shadow-lg);
}

.modal-overlay.active .modal {
    transform: translateY(0) scale(1);
}

.modal-title {
    font-size: 1.15rem;
    font-weight: 600;
    margin-bottom: 20px;
}

.modal-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 24px;
}

/* ===== Skill Cards ===== */
.skill-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 16px;
}

.skill-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px;
    cursor: pointer;
    transition: border-color var(--transition), transform var(--transition), box-shadow var(--transition);
}

.skill-card:hover {
    border-color: var(--accent);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.25);
}

.skill-card-evolved {
    border-left: 3px solid var(--orange, #f97316);
    background: linear-gradient(135deg, var(--bg-card) 0%, rgba(249,115,22,0.03) 100%);
}

.skill-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
}

.skill-name {
    font-weight: 600;
    font-size: 1.02rem;
}

.skill-desc {
    font-size: 0.85rem;
    color: var(--text-secondary);
    margin-bottom: 12px;
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.skill-users {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

/* ===== Knowledge List ===== */
.knowledge-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.knowledge-item {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 16px 20px;
    display: flex;
    align-items: flex-start;
    gap: 16px;
}

.knowledge-item-body { flex: 1; }

.knowledge-title {
    font-weight: 600;
    margin-bottom: 4px;
}

.knowledge-meta {
    font-size: 0.82rem;
    color: var(--text-muted);
    display: flex;
    gap: 12px;
    flex-wrap: wrap;

/* ===== Markdown Body ===== */
}
.markdown-body img {
    max-width: 100%;
    height: auto;
    border-radius: 6px;
    margin: 8px 0;
    cursor: pointer;
}
.markdown-body img:hover { opacity: 0.9; }
.markdown-body pre {
    background: var(--bg-primary);
    padding: 12px;
    border-radius: 6px;
    overflow-x: auto;
    font-size: 0.85rem;
    margin: 8px 0;
}
.markdown-body code {
    background: var(--bg-primary);
    padding: 2px 6px;
    border-radius: 3px;
    font-size: 0.88em;
}
.markdown-body pre code { background: none; padding: 0; }
.markdown-body table {
    border-collapse: collapse;
    width: 100%;
    margin: 8px 0;
}
.markdown-body th, .markdown-body td {
    border: 1px solid var(--border);
    padding: 6px 10px;
    font-size: 0.88rem;
}
.markdown-body th { background: var(--bg-primary); font-weight: 600; }
.markdown-body blockquote {
    border-left: 3px solid var(--accent);
    padding-left: 12px;
    margin: 8px 0;
    color: var(--text-secondary);
}
.markdown-body h1, .markdown-body h2, .markdown-body h3, .markdown-body h4 {
    margin: 14px 0 8px;
}
.markdown-body ul, .markdown-body ol { margin-left: 20px; }
.markdown-body a { color: var(--accent); }
}

/* ===== Toast ===== */
/* (see end of file for enhanced toast with backdrop-filter) */

/* ===== Timeline ===== */
.timeline {
    position: relative;
    padding-left: 24px;
}

.timeline::before {
    content: '';
    position: absolute;
    left: 8px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: var(--border);
}

.timeline-item {
    position: relative;
    margin-bottom: 20px;
    padding: 16px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
}

.timeline-item::before {
    content: '';
    position: absolute;
    left: -20px;
    top: 20px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--accent);
    border: 2px solid var(--bg-primary);
}

.timeline-time {
    font-size: 0.82rem;
    color: var(--text-muted);
    margin-bottom: 6px;
}

/* ===== Empty State ===== */
/* (see end of file for enhanced version) */

/* ===== Section ===== */
.section { margin-bottom: 24px; }
.section-title {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 14px;
    color: var(--text-primary);
}

/* ===== Two Column Layout ===== */
.two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

@media (max-width: 900px) {
    .two-col { grid-template-columns: 1fr; }
}

/* ===== Loading ===== */
/* (see end of file for enhanced spinner) */
.loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px;
    color: var(--text-muted);
}

@keyframes spin { to { transform: rotate(360deg); } }

/* ===== Tab Bar ===== */
.tab-bar {
    display: flex;
    gap: 2px;
    border-bottom: 1px solid var(--border);
    margin-bottom: 20px;
}

.tab-item {
    padding: 10px 18px;
    font-size: 0.88rem;
    font-weight: 500;
    color: var(--text-secondary);
    cursor: pointer;
    border-bottom: 2px solid transparent;
    transition: all var(--transition);
}

.tab-item:hover { color: var(--text-primary); }

.tab-item.active {
    color: var(--accent);
    border-bottom-color: var(--accent);
    font-weight: 600;
}

/* ===== Hub / Agent Communication ===== */
.hub-container {
    display: grid;
    grid-template-columns: 240px 1fr 300px;
    gap: 20px;
    height: calc(100vh - 120px);
}

.hub-sidebar {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.hub-main {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.hub-inbox {}

.panel {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
}

.panel-header {
    padding: 14px 16px;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.panel-header h3 {
    font-size: 0.95rem;
    font-weight: 600;
}

.count-badge {
    background: var(--accent-dim);
    color: var(--accent);
    padding: 2px 8px;
    border-radius: 99px;
    font-size: 0.78rem;
    font-weight: 600;
}

/* Agent List */
.agent-list {
    padding: 8px;
    max-height: 300px;
    overflow-y: auto;
}

.agent-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: background 0.15s;
}

.agent-item:hover {
    background: var(--bg-hover);
}

.agent-item.selected {
    background: var(--accent-dim);
}

.agent-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--accent-dim);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    color: var(--accent);
    flex-shrink: 0;
}

.agent-info {
    flex: 1;
    min-width: 0;
}

.agent-name {
    font-weight: 600;
    font-size: 0.9rem;
}

.agent-key {
    font-size: 0.75rem;
    color: var(--text-muted);
}

/* Stats Grid */
.stats-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1px;
    background: var(--border);
}

.stat-item {
    background: var(--bg-card);
    padding: 14px;
    text-align: center;
}

.stat-item .stat-value {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--accent);
}

.stat-item .stat-label {
    font-size: 0.75rem;
    color: var(--text-muted);
}

/* Conversation List */
.conversations-panel {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
}

.conversation-list {
    flex: 1;
    overflow-y: auto;
    padding: 8px;
}

.conversation-item {
    padding: 12px;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: background 0.15s;
}

.conversation-item:hover {
    background: var(--bg-hover);
}

.conversation-peer {
    font-weight: 600;
    font-size: 0.9rem;
    margin-bottom: 2px;
}

.conversation-preview {
    font-size: 0.82rem;
    color: var(--text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Message Compose */
.message-compose {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
}

.compose-recipient {
    padding: 10px 14px;
    border-bottom: 1px solid var(--border);
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.recipient-label {
    color: var(--text-muted);
}

.compose-input {
    display: flex;
    gap: 10px;
    padding: 12px;
    align-items: flex-end;
}

.compose-input textarea {
    flex: 1;
    resize: none;
    background: var(--bg-input);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text-primary);
    padding: 10px 12px;
    font-family: inherit;
    font-size: 0.9rem;
    outline: none;
}

.compose-input textarea:focus {
    border-color: var(--accent);
}

/* Inbox List */
.inbox-list {
    padding: 8px;
    max-height: calc(100vh - 200px);
    overflow-y: auto;
}

.inbox-item {
    padding: 12px;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: background 0.15s;
    margin-bottom: 4px;
}

.inbox-item:hover {
    background: var(--bg-hover);
}

.inbox-item.unread {
    background: var(--accent-dim);
}

.msg-sender {
    font-weight: 600;
    font-size: 0.88rem;
    margin-bottom: 2px;
}

.msg-content {
    font-size: 0.82rem;
    color: var(--text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.msg-time {
    font-size: 0.72rem;
    color: var(--text-muted);
    margin-top: 4px;
}

.status-badge {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 99px;
    font-size: 0.82rem;
}

.action-buttons {
    display: flex;
    gap: 8px;
}

@media (max-width: 1200px) {
    .hub-container {
        grid-template-columns: 1fr 280px;
    }
    .hub-inbox {
        display: none;
    }
}

/* ===== Chat Messages ===== */
.chat-messages {
    flex: 1;
    overflow-y: auto;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    max-height: calc(100vh - 340px);
}

.chat-msg {
    max-width: 75%;
    padding: 10px 14px;
    border-radius: var(--radius);
    font-size: 0.88rem;
}

.chat-msg-recv {
    align-self: flex-start;
    background: var(--bg-hover);
    border: 1px solid var(--border);
}

.chat-msg-sent {
    align-self: flex-end;
    background: var(--accent-dim);
    border: 1px solid var(--accent);
}

.chat-msg-sender {
    font-size: 0.75rem;
    color: var(--text-muted);
    margin-bottom: 4px;
    font-weight: 600;
}

.chat-msg-content {
    line-height: 1.5;
    word-break: break-word;
}

.chat-msg-time {
    font-size: 0.7rem;
    color: var(--text-muted);
    margin-top: 4px;
    text-align: right;
}

/* ===== Reports Center ===== */
.report-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    background: none;
    margin-bottom: 24px;
}

.report-progress-bar {
    margin-bottom: 20px;
}

.progress-track {
    height: 8px;
    background: var(--bg-hover);
    border-radius: 4px;
    overflow: hidden;
}

.progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--green), var(--accent));
    border-radius: 4px;
    transition: width 0.6s ease;
}

.claw-report-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 10px;
}

.claw-report-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    transition: all 0.15s;
}

.claw-report-item.reported {
    background: var(--green-dim);
    border-color: rgba(34, 197, 94, 0.3);
}

.claw-report-item.not-reported {
    background: var(--bg-hover);
}

.claw-report-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--accent-dim);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    flex-shrink: 0;
}

.claw-report-info {
    flex: 1;
    min-width: 0;
}

.claw-report-name {
    font-weight: 600;
    font-size: 0.9rem;
}

.claw-report-detail {
    margin-top: 2px;
}

/* Report List Items */
.report-date-group {
    margin-bottom: 20px;
}

.report-date-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--border);
}

.report-date-label {
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--text-primary);
}

.report-item {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 16px 20px;
    margin-bottom: 10px;
    cursor: pointer;
    transition: border-color 0.15s, box-shadow 0.15s;
}

.report-item:hover {
    border-color: var(--accent);
    box-shadow: 0 0 0 1px var(--accent-dim);
}

.report-item-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 8px;
}

.report-summary {
    font-size: 0.85rem;
    color: var(--text-secondary);
    line-height: 1.6;
    padding: 10px;
    background: var(--bg-hover);
    border-radius: var(--radius-sm);
    border-left: 3px solid var(--accent);
}

.detail-list {
    list-style: none;
    padding: 0;
}

.detail-list li {
    padding: 8px 0;
    border-bottom: 1px solid var(--border);
    font-size: 0.88rem;
    color: var(--text-secondary);
}

.detail-list li:before {
    content: '•';
    color: var(--accent);
    margin-right: 8px;
    font-weight: 600;
}

.detail-list li:last-child {
    border-bottom: none;
}

/* ===== TAPD Integration ===== */
.tapd-table {
    display: flex;
    flex-direction: column;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
}

.tapd-table-header {
    display: flex;
    gap: 12px;
    padding: 12px 16px;
    background: var(--bg-secondary);
    border-bottom: 1px solid var(--border);
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--text-muted);
}

.tapd-table-row {
    display: flex;
    gap: 12px;
    padding: 12px 16px;
    border-bottom: 1px solid var(--border);
    font-size: 0.88rem;
    align-items: center;
    transition: background 0.15s;
}

.tapd-table-row:last-child {
    border-bottom: none;
}

.tapd-table-row:hover {
    background: var(--bg-hover);
}

/* ===== Skills Market - Marketplace Style ===== */
.market-header {
    margin-bottom: 24px;
}

.market-search {
    position: relative;
    margin-bottom: 20px;
}

.market-search input {
    width: 100%;
    padding: 12px 16px 12px 44px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--text-primary);
    font-size: 0.95rem;
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.market-search input:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-dim);
}

.market-search-icon {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.1rem;
    color: var(--text-muted);
}

.market-filters {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 20px;
}

.filter-chip {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 99px;
    font-size: 0.85rem;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.15s;
}

.filter-chip:hover {
    border-color: var(--accent);
    color: var(--text-primary);
}

.filter-chip.active {
    background: var(--accent-dim);
    border-color: var(--accent);
    color: var(--accent);
}

.filter-chip-icon { font-size: 0.9rem; }

/* Market Grid */
.market-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 16px;
}

/* Skill Card - Enhanced Marketplace Style */
.skill-card-market {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 0;
    overflow: hidden;
    transition: all 0.2s;
    cursor: pointer;
    position: relative;
}

.skill-card-market:hover {
    border-color: var(--accent);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.3);
}

.skill-card-market.featured {
    border-color: var(--yellow);
    background: linear-gradient(135deg, var(--bg-card) 0%, rgba(245,158,11,0.05) 100%);
}

.skill-card-market.featured::before {
    content: '⭐ 精选';
    position: absolute;
    top: 10px;
    right: 10px;
    padding: 3px 8px;
    background: var(--yellow);
    color: #000;
    font-size: 0.72rem;
    font-weight: 600;
    border-radius: 4px;
}

.skill-card-top {
    padding: 16px 18px 12px;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: flex-start;
    gap: 12px;
}

.skill-icon-box {
    width: 42px;
    height: 42px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    flex-shrink: 0;
}

.skill-icon-box.standard { background: var(--accent-dim); }
.skill-icon-box.custom { background: var(--blue-dim); }
.skill-icon-box.evolved { background: rgba(249,115,22,0.15); }

.skill-card-title-area {
    flex: 1;
    min-width: 0;
}

.skill-card-name {
    font-weight: 600;
    font-size: 1rem;
    margin-bottom: 4px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.skill-card-desc {
    font-size: 0.82rem;
    color: var(--text-secondary);
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.skill-card-body {
    padding: 12px 18px;
}

.skill-meta-row {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 0.78rem;
    color: var(--text-muted);
    margin-bottom: 10px;
}

.skill-meta-item {
    display: flex;
    align-items: center;
    gap: 4px;
}

.skill-rating {
    display: flex;
    align-items: center;
    gap: 3px;
    color: var(--yellow);
}

.skill-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 10px;
}

/* Evolved Skills Metrics */
.evolved-metrics-bar {
    margin: 10px 0;
}

.evolved-rate-row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 6px;
}

.evolved-rate-label {
    font-size: 0.75rem;
    color: var(--text-muted);
    min-width: 45px;
}

.evolved-rate-track {
    flex: 1;
    height: 5px;
    background: var(--border);
    border-radius: 3px;
    overflow: hidden;
}

.evolved-rate-fill {
    height: 100%;
    border-radius: 3px;
    transition: width 0.4s;
}

.evolved-rate-fill.high { background: var(--green); }
.evolved-rate-fill.medium { background: var(--yellow); }
.evolved-rate-fill.low { background: var(--red); }

.evolved-rate-value {
    font-size: 0.78rem;
    font-weight: 600;
    min-width: 38px;
    text-align: right;
}

.evolved-stats-row {
    display: flex;
    gap: 16px;
    font-size: 0.75rem;
    color: var(--text-muted);
    padding-top: 8px;
    border-top: 1px solid var(--border);
}

/* Skill Card Footer */
.skill-card-footer {
    padding: 10px 18px;
    background: var(--bg-secondary);
    border-top: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.skill-install-count {
    font-size: 0.78rem;
    color: var(--text-muted);
    display: flex;
    align-items: center;
    gap: 4px;
}

.skill-action-btn {
    padding: 5px 12px;
    font-size: 0.8rem;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.15s;
}

/* Skill Detail Modal - Large */
.skill-detail-modal .modal {
    max-width: 680px;
}

.skill-detail-header {
    display: flex;
    gap: 16px;
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--border);
}

.skill-detail-icon {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.8rem;
    flex-shrink: 0;
}

.skill-detail-title-area { flex: 1; }

.skill-detail-name {
    font-size: 1.3rem;
    font-weight: 700;
    margin-bottom: 6px;
}

.skill-detail-meta {
    display: flex;
    gap: 12px;
    font-size: 0.82rem;
    color: var(--text-muted);
}

.skill-detail-section {
    margin-bottom: 16px;
}

.skill-detail-section-title {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-secondary);
    margin-bottom: 8px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.skill-detail-desc {
    font-size: 0.92rem;
    line-height: 1.6;
    color: var(--text-primary);
}

.skill-template-preview {
    background: var(--bg-primary);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 14px;
    font-family: 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.82rem;
    line-height: 1.5;
    color: var(--text-secondary);
    max-height: 180px;
    overflow-y: auto;
    white-space: pre-wrap;
}

.skill-evolve-history {
    background: var(--bg-primary);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 14px;
}

.evolve-history-item {
    display: flex;
    gap: 10px;
    padding: 8px 0;
    border-bottom: 1px solid var(--border);
    font-size: 0.85rem;
}

.evolve-history-item:last-child { border-bottom: none; }

.evolve-history-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--accent);
    margin-top: 6px;
    flex-shrink: 0;
}

.evolve-history-content { flex: 1; }
.evolve-history-action { color: var(--text-primary); font-weight: 500; }
.evolve-history-time { font-size: 0.78rem; color: var(--text-muted); margin-top: 2px; }

/* ===== Agent Topology Visualization ===== */
.topology-container {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px;
    margin-bottom: 20px;
    position: relative;
    overflow: hidden;
}

.topology-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}

.topology-title {
    font-size: 1rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 8px;
}

.topology-canvas {
    width: 100%;
    height: 320px;
    position: relative;
    background: radial-gradient(circle at center, var(--bg-secondary) 0%, var(--bg-primary) 100%);
    border-radius: var(--radius-sm);
}

/* Hex Node */
.hex-node {
    position: absolute;
    width: 72px;
    height: 72px;
    cursor: pointer;
    transition: transform 0.2s;
}

.hex-node:hover { transform: scale(1.1); z-index: 10; }

.hex-node-inner {
    width: 100%;
    height: 100%;
    clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    position: relative;
}

.hex-node-inner.human {
    background: linear-gradient(135deg, var(--accent) 0%, #8b5cf6 100%);
}

.hex-node-inner.ai {
    background: linear-gradient(135deg, var(--green) 0%, #10b981 100%);
}

.hex-node-inner.busy {
    background: linear-gradient(135deg, var(--yellow) 0%, #f59e0b 100%);
}

.hex-node-inner.offline {
    background: var(--bg-hover);
}

.hex-node-avatar {
    font-size: 1.4rem;
}

.hex-node-name {
    font-size: 0.68rem;
    font-weight: 600;
    color: #fff;
    text-align: center;
    max-width: 60px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.hex-node.offline .hex-node-name { color: var(--text-muted); }

.hex-node-status {
    position: absolute;
    top: 2px;
    right: 2px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    border: 2px solid var(--bg-card);
}

.hex-node-status.online { background: var(--green); }
.hex-node-status.busy { background: var(--yellow); }
.hex-node-status.offline { background: var(--text-muted); }

/* Connection Lines */
.topology-line {
    position: absolute;
    height: 2px;
    background: linear-gradient(90deg, var(--accent), var(--blue));
    opacity: 0.3;
    transform-origin: left center;
    pointer-events: none;
}

/* Topology Legend */
.topology-legend {
    display: flex;
    gap: 20px;
    margin-top: 14px;
    justify-content: center;
}

.legend-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.78rem;
    color: var(--text-muted);
}

.legend-dot {
    width: 12px;
    height: 12px;
    border-radius: 3px;
}

.legend-dot.ai { background: var(--green); }
.legend-dot.human { background: var(--accent); }
.legend-dot.busy { background: var(--yellow); }

/* Node Detail Tooltip */
.node-tooltip {
    position: absolute;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 12px 16px;
    min-width: 180px;
    z-index: 100;
    box-shadow: 0 4px 16px rgba(0,0,0,0.3);
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.15s;
}

.node-tooltip.visible { opacity: 1; }

.tooltip-name {
    font-weight: 600;
    font-size: 0.95rem;
    margin-bottom: 4px;
}

.tooltip-role {
    font-size: 0.82rem;
    color: var(--text-secondary);
    margin-bottom: 6px;
}

.tooltip-meta {
    font-size: 0.75rem;
    color: var(--text-muted);
    display: flex;
    flex-direction: column;
    gap: 2px;
}

/* ===== OpenClaw Cards - Enhanced ===== */
.claw-card-market {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 0;
    overflow: hidden;
    transition: all 0.2s;
    cursor: pointer;
}

.claw-card-market:hover {
    border-color: var(--accent);
    box-shadow: 0 4px 20px rgba(0,0,0,0.25);
}

.claw-card-top-bar {
    height: 4px;
    background: linear-gradient(90deg, var(--accent), var(--blue));
}

.claw-card-content {
    padding: 18px;
}

.claw-card-avatar-row {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
}

.claw-avatar-market {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: var(--accent-dim);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
}

.claw-market-info { flex: 1; }

.claw-market-name {
    font-weight: 600;
    font-size: 1.05rem;
    margin-bottom: 2px;
}

.claw-market-role {
    font-size: 0.82rem;
    color: var(--text-secondary);
}

.claw-status-indicator {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 0.78rem;
    padding: 4px 10px;
    border-radius: 99px;
    background: var(--bg-hover);
}

.claw-status-indicator.online { color: var(--green); background: var(--green-dim); }
.claw-status-indicator.busy { color: var(--yellow); background: var(--yellow-dim); }
.claw-status-indicator.offline { color: var(--text-muted); }

.claw-card-skills-preview {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    margin-top: 10px;
}

.claw-skill-chip {
    padding: 3px 8px;
    background: var(--bg-hover);
    border-radius: 4px;
    font-size: 0.72rem;
    color: var(--text-secondary);
}

/* ===== Enhanced Micro-Interactions ===== */

/* Scrollbar styling */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--border-light); }

/* Selection highlight */
::selection { background: var(--accent-dim); color: var(--accent); }

/* Focus visible for accessibility */
:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    border-radius: 4px;
}

/* Section titles with subtle decoration */
.section-title {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 14px;
    color: var(--text-primary);
    letter-spacing: -0.01em;
}

/* Avatar with status indicator */
.claw-avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--accent-dim);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    flex-shrink: 0;
    position: relative;
}

/* Subtle gradient decoration for sidebar */
.sidebar::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 120px;
    background: linear-gradient(to top, var(--bg-secondary), transparent);
    pointer-events: none;
    z-index: 0;
}

/* Dashboard tab indicators */
.dashboard-tab {
    background: none; border: none;
    padding: 10px 20px; font-size: 0.86rem; font-weight: 600;
    color: var(--text-muted); cursor: pointer;
    border-bottom: 2px solid transparent; margin-bottom: -2px;
    transition: all var(--transition);
    letter-spacing: 0.01em;
}
.dashboard-tab:hover { color: var(--text-primary); }
.dashboard-tab.active {
    color: var(--accent);
    border-bottom-color: var(--accent);
}

/* Stat card with subtle glow on hover */
.stat-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    transition: border-color var(--transition), box-shadow var(--transition);
}
.stat-card:hover {
    border-color: var(--border-light);
    box-shadow: 0 2px 12px rgba(0,0,0,0.15);
}

/* Empty state refinement */
.empty-state {
    text-align: center;
    padding: 52px 20px;
    color: var(--text-muted);
}
.empty-state-icon {
    font-size: 2.8rem;
    margin-bottom: 14px;
    opacity: 0.6;
}
.empty-state-text {
    font-size: 0.92rem;
    margin-bottom: 16px;
    letter-spacing: 0.01em;
}

/* Progress bar with gradient animation */
.progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--green), var(--accent));
    border-radius: 4px;
    transition: width 0.6s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    overflow: hidden;
}
.progress-fill::after {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.08), transparent);
    animation: progressShimmer 2s infinite;
}
@keyframes progressShimmer {
    0% { transform: translateX(-100%); }
    100% { transform: translateX(100%); }
}

/* Quick link cards with refined hover */
.quick-link-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 20px 12px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    transition: all var(--transition);
    text-decoration: none;
}
.quick-link-card:hover {
    border-color: var(--accent);
    background: var(--accent-dim);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}

/* Content area with subtle background texture */
.content-area {
    padding: 24px 28px;
    flex: 1;
    position: relative;
}

/* Refined loading spinner */
.spinner {
    width: 22px;
    height: 22px;
    border: 2.5px solid var(--border);
    border-top-color: var(--accent);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    margin-right: 10px;
}

/* Toast notification refinement */
.toast {
    position: fixed;
    bottom: 24px;
    right: 24px;
    padding: 12px 20px;
    border-radius: 10px;
    font-size: 0.88rem;
    z-index: 300;
    opacity: 0;
    transform: translateY(10px);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backdrop-filter: blur(8px);
    font-weight: 500;
}
.toast.show {
    opacity: 1;
    transform: translateY(0);
}
.toast-info    { background: var(--blue-soft);   color: var(--blue);   border: 1px solid var(--blue-dim); }
.toast-success { background: var(--green-soft);  color: var(--green);  border: 1px solid var(--green-dim); }
.toast-error   { background: var(--red-soft);    color: var(--red);    border: 1px solid var(--red-dim); }
.toast-warning { background: var(--amber-soft);  color: var(--yellow); border: 1px solid var(--yellow-dim); }

@media (max-width: 900px) {
    .report-stats {
        grid-template-columns: repeat(2, 1fr);
    }
    .claw-report-grid {
        grid-template-columns: 1fr;
    }
    .market-grid {
        grid-template-columns: 1fr;
    }
}

/* =====================================================================
   ★ Sample D Component Library — 新增标准化控件
   适配明/暗双主题，外观与 _design_samples/sample-d-components.html 对齐
   ===================================================================== */

/* ---------- Buttons (扩展) ---------- */
.btn-outline {
    background: transparent;
    color: var(--text-primary);
    border: 1px solid var(--border);
}
.btn-outline:hover { background: var(--bg-hover); border-color: var(--border-light); }

.btn-outline-danger {
    background: transparent;
    color: var(--red);
    border: 1px solid var(--red-dim);
}
.btn-outline-danger:hover { background: var(--red-soft); border-color: var(--red); }

.btn-link {
    background: none; border: none; padding: 0;
    color: var(--accent); cursor: pointer;
    font-size: inherit;
}
.btn-link:hover { color: var(--accent-hover); text-decoration: underline; }

.icon-btn {
    display: inline-flex; align-items: center; justify-content: center;
    width: 32px; height: 32px;
    border-radius: 8px;
    background: transparent;
    border: 1px solid transparent;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all var(--transition);
}
.icon-btn:hover { background: var(--bg-hover); color: var(--text-primary); border-color: var(--border); }
.icon-btn.active { background: var(--accent-soft); color: var(--accent); border-color: var(--accent-dim); }
.icon-btn svg { width: 16px; height: 16px; }

.btn-group {
    display: inline-flex;
    border: 1px solid var(--border);
    border-radius: 8px;
    overflow: hidden;
    background: var(--bg-card);
}
.btn-group > .btn,
.btn-group > button {
    border-radius: 0;
    border: none;
    border-right: 1px solid var(--border);
    background: transparent;
    color: var(--text-secondary);
    padding: 6px 14px;
    font-size: 0.85rem;
    cursor: pointer;
    transition: all var(--transition);
}
.btn-group > *:last-child { border-right: none; }
.btn-group > *:hover { background: var(--bg-hover); color: var(--text-primary); }
.btn-group > *.active {
    background: var(--accent-soft);
    color: var(--accent);
    font-weight: 600;
}

/* ---------- Segmented control ---------- */
.segmented {
    display: inline-flex;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 3px;
    gap: 2px;
}
.segmented > button,
.segmented > label {
    border: none; background: transparent;
    padding: 5px 14px;
    font-size: 0.84rem;
    color: var(--text-secondary);
    border-radius: 7px;
    cursor: pointer;
    transition: all var(--transition);
}
.segmented > *:hover { color: var(--text-primary); }
.segmented > *.active,
.segmented > input[type="radio"]:checked + label {
    background: var(--bg-card);
    color: var(--text-primary);
    font-weight: 600;
    box-shadow: var(--shadow-sm);
}

/* ---------- Form: input wrappers, validation states, sizes ---------- */
.field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.field-label { font-size: 0.82rem; font-weight: 500; color: var(--text-secondary); }
.field-hint  { font-size: 0.78rem; color: var(--text-muted); }
.field-error { font-size: 0.78rem; color: var(--red); display: flex; align-items: center; gap: 4px; }

.form-input.is-error,
.form-select.is-error,
.form-textarea.is-error {
    border-color: var(--red);
    box-shadow: 0 0 0 3px var(--red-dim);
}
.form-input.is-success,
.form-select.is-success,
.form-textarea.is-success {
    border-color: var(--green);
    box-shadow: 0 0 0 3px var(--green-dim);
}

.input-wrap {
    position: relative;
    display: flex;
    align-items: center;
}
.input-wrap > .form-input { padding-left: 36px; }
.input-wrap > .input-icon {
    position: absolute;
    left: 12px;
    color: var(--text-muted);
    pointer-events: none;
    display: inline-flex;
}
.input-wrap > .input-icon svg { width: 16px; height: 16px; }
.input-wrap > .input-suffix {
    position: absolute;
    right: 12px;
    font-size: 0.8rem;
    color: var(--text-muted);
}

.input-group {
    display: flex;
    align-items: stretch;
}
.input-group > .form-input,
.input-group > .form-select {
    border-radius: 0;
}
.input-group > *:first-child { border-top-left-radius: 8px; border-bottom-left-radius: 8px; }
.input-group > *:last-child  { border-top-right-radius: 8px; border-bottom-right-radius: 8px; }
.input-group > * + * { margin-left: -1px; }
.input-group-addon {
    display: inline-flex; align-items: center;
    padding: 0 12px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    font-size: 0.85rem;
    white-space: nowrap;
}

.form-input-sm, .form-select-sm { padding: 6px 10px; font-size: 0.82rem; }
.form-input-lg, .form-select-lg { padding: 12px 14px; font-size: 1rem; }

/* Native select arrow polish */
.form-select {
    appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238a8780' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 32px;
}

/* ---------- Checkbox / Radio (custom styled) ---------- */
.check, .radio {
    display: inline-flex;
    align-items: flex-start;
    gap: 8px;
    cursor: pointer;
    user-select: none;
    font-size: 0.88rem;
    color: var(--text-primary);
    line-height: 1.4;
}
.check > input[type="checkbox"],
.radio > input[type="radio"] {
    appearance: none;
    -webkit-appearance: none;
    width: 16px; height: 16px;
    margin: 0;
    flex-shrink: 0;
    margin-top: 2px;
    background: var(--bg-card);
    border: 1.5px solid var(--border-light);
    cursor: pointer;
    transition: all var(--transition);
    position: relative;
}
.check > input[type="checkbox"] { border-radius: 4px; }
.radio > input[type="radio"]    { border-radius: 50%; }

.check > input[type="checkbox"]:hover,
.radio > input[type="radio"]:hover {
    border-color: var(--accent);
}

.check > input[type="checkbox"]:checked {
    background: var(--accent);
    border-color: var(--accent);
}
.check > input[type="checkbox"]:checked::after {
    content: '';
    position: absolute;
    left: 4px; top: 1px;
    width: 4px; height: 8px;
    border: solid var(--accent-fg, #fff);
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}
.check > input[type="checkbox"]:indeterminate {
    background: var(--accent);
    border-color: var(--accent);
}
.check > input[type="checkbox"]:indeterminate::after {
    content: '';
    position: absolute;
    left: 3px; top: 6px;
    width: 8px; height: 2px;
    background: var(--accent-fg, #fff);
}

.radio > input[type="radio"]:checked {
    border-color: var(--accent);
    background: var(--bg-card);
}
.radio > input[type="radio"]:checked::after {
    content: '';
    position: absolute;
    left: 50%; top: 50%;
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--accent);
    transform: translate(-50%, -50%);
}

.check > input:focus-visible,
.radio > input:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}
.check.disabled, .radio.disabled,
.check > input:disabled, .radio > input:disabled {
    opacity: .5; cursor: not-allowed;
}

/* 兼容旧模板里散落的原生 checkbox/radio */
input[type="checkbox"]:not([class]),
input[type="radio"]:not([class]) {
    accent-color: var(--accent);
    cursor: pointer;
}

/* ---------- Switch / Toggle ---------- */
.switch {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    user-select: none;
    font-size: 0.88rem;
}
.switch > input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 36px; height: 20px;
    background: var(--border-light);
    border-radius: 999px;
    position: relative;
    cursor: pointer;
    transition: background var(--transition);
    flex-shrink: 0;
    margin: 0;
}
.switch > input[type="checkbox"]::before {
    content: '';
    position: absolute;
    left: 2px; top: 2px;
    width: 16px; height: 16px;
    background: #fff;
    border-radius: 50%;
    box-shadow: 0 1px 2px rgba(0,0,0,.2);
    transition: transform var(--transition);
}
.switch > input[type="checkbox"]:checked {
    background: var(--accent);
}
.switch > input[type="checkbox"]:checked::before {
    transform: translateX(16px);
}
.switch > input[type="checkbox"]:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}
.switch.sm > input[type="checkbox"] { width: 28px; height: 16px; }
.switch.sm > input[type="checkbox"]::before { width: 12px; height: 12px; }
.switch.sm > input[type="checkbox"]:checked::before { transform: translateX(12px); }

/* ---------- Multi-select / Chip input ---------- */
.multiselect {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    padding: 6px;
    min-height: 38px;
    background: var(--bg-input);
    border: 1px solid var(--border);
    border-radius: 8px;
    cursor: text;
    transition: border-color var(--transition);
}
.multiselect:focus-within {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-dim);
}
.multiselect > input {
    flex: 1; min-width: 80px;
    border: none; outline: none; background: transparent;
    padding: 4px 6px;
    color: var(--text-primary);
    font-size: 0.88rem;
    font-family: inherit;
}
.chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 3px 4px 3px 10px;
    background: var(--accent-soft);
    color: var(--accent);
    border-radius: 6px;
    font-size: 0.8rem;
    font-weight: 500;
}
.chip > .chip-remove {
    display: inline-flex; align-items: center; justify-content: center;
    width: 16px; height: 16px;
    border-radius: 4px;
    border: none; background: transparent;
    color: inherit; cursor: pointer;
    opacity: .7;
}
.chip > .chip-remove:hover { background: rgba(0,0,0,.08); opacity: 1; }

/* ---------- Dropdown menu ---------- */
.dropdown { position: relative; display: inline-block; }
.dropdown-menu {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    min-width: 180px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 10px;
    box-shadow: var(--shadow-lg);
    padding: 4px;
    z-index: 250;
    opacity: 0;
    transform: translateY(-4px);
    pointer-events: none;
    transition: opacity .15s, transform .15s;
}
.dropdown.open > .dropdown-menu,
.dropdown-menu.show {
    opacity: 1; transform: translateY(0); pointer-events: auto;
}
.dropdown-menu.right { left: auto; right: 0; }
.dropdown-item {
    display: flex; align-items: center; gap: 10px;
    padding: 7px 10px;
    font-size: 0.86rem;
    color: var(--text-primary);
    border-radius: 6px;
    cursor: pointer;
    background: none; border: none; width: 100%; text-align: left;
}
.dropdown-item:hover { background: var(--bg-hover); }
.dropdown-item.danger { color: var(--red); }
.dropdown-item.danger:hover { background: var(--red-soft); }
.dropdown-item .dropdown-shortcut { margin-left: auto; color: var(--text-muted); font-size: 0.78rem; font-family: var(--font-mono, monospace); }
.dropdown-divider { height: 1px; background: var(--border); margin: 4px 2px; }
.dropdown-section-title {
    padding: 6px 10px 2px;
    font-size: 0.72rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
}

/* ---------- Tags / Badges (扩展) ---------- */
.tag-rose   { background: var(--rose-soft);   color: var(--rose); }
.tag-amber  { background: var(--amber-soft);  color: var(--yellow); }
.tag-mono   { background: var(--bg-hover);    color: var(--text-secondary); font-family: var(--font-mono, monospace); font-size: 0.74rem; }
.tag-square { border-radius: 4px; padding: 1px 6px; font-size: 0.74rem; font-weight: 600; }
.tag-dot    { padding-left: 8px; position: relative; }
.tag-dot::before {
    content: ''; display: inline-block;
    width: 6px; height: 6px; border-radius: 50%;
    background: currentColor;
    margin-right: 6px;
}
.badge-num {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 18px; height: 18px;
    padding: 0 5px;
    border-radius: 9px;
    background: var(--accent);
    color: var(--accent-fg, #fff);
    font-size: 0.7rem; font-weight: 700;
    line-height: 1;
}
.badge-num.muted { background: var(--bg-hover); color: var(--text-secondary); }

/* ---------- Banner / Alert ---------- */
.banner {
    display: flex; align-items: flex-start; gap: 10px;
    padding: 12px 16px;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: var(--bg-card);
    font-size: 0.88rem;
    color: var(--text-primary);
}
.banner-icon { flex-shrink: 0; margin-top: 2px; display: inline-flex; }
.banner-icon svg { width: 16px; height: 16px; }
.banner-body { flex: 1; }
.banner-title { font-weight: 600; margin-bottom: 2px; }
.banner-close { background: none; border: none; color: var(--text-muted); cursor: pointer; padding: 0; }
.banner-info    { background: var(--blue-soft);   border-color: var(--blue-dim);    color: var(--blue); }
.banner-success { background: var(--green-soft);  border-color: var(--green-dim);   color: var(--green); }
.banner-warning { background: var(--amber-soft);  border-color: var(--yellow-dim);  color: var(--yellow); }
.banner-error   { background: var(--red-soft);    border-color: var(--red-dim);     color: var(--red); }

/* ---------- Table ---------- */
.tbl {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 10px;
    overflow: hidden;
    font-size: 0.88rem;
}
.tbl th, .tbl td {
    padding: 10px 14px;
    text-align: left;
    border-bottom: 1px solid var(--border);
}
.tbl thead th {
    background: var(--bg-secondary);
    font-weight: 600;
    color: var(--text-secondary);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.tbl tbody tr:last-child td { border-bottom: none; }
.tbl tbody tr:hover { background: var(--bg-hover); }
.tbl tbody tr.selected { background: var(--accent-soft); }
.tbl-compact th, .tbl-compact td { padding: 6px 10px; }
.tbl .col-actions { width: 1%; white-space: nowrap; }

/* ---------- Pagination ---------- */
.pager {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.pager > button,
.pager > a {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 30px; height: 30px;
    padding: 0 8px;
    border: 1px solid var(--border);
    background: var(--bg-card);
    color: var(--text-secondary);
    border-radius: 6px;
    cursor: pointer;
    font-size: 0.85rem;
    transition: all var(--transition);
}
.pager > *:hover:not([disabled]) {
    border-color: var(--accent);
    color: var(--accent);
}
.pager > *.active {
    background: var(--accent);
    border-color: var(--accent);
    color: var(--accent-fg, #fff);
    font-weight: 600;
}
.pager > *[disabled] { opacity: .4; cursor: not-allowed; }
.pager-ellipsis { display: inline-flex; align-items: center; padding: 0 6px; color: var(--text-muted); }

/* ---------- Empty state (扩展) ---------- */
.empty {
    text-align: center;
    padding: 56px 24px;
    color: var(--text-muted);
}
.empty-icon {
    width: 56px; height: 56px;
    margin: 0 auto 16px;
    border-radius: 14px;
    background: var(--bg-secondary);
    display: inline-flex;
    align-items: center; justify-content: center;
    color: var(--text-muted);
}
.empty-icon svg { width: 24px; height: 24px; }
.empty-title  { font-size: 1rem; font-weight: 600; color: var(--text-primary); margin-bottom: 6px; }
.empty-desc   { font-size: 0.85rem; color: var(--text-secondary); margin-bottom: 18px; }
.empty-action { display: inline-flex; gap: 8px; }

/* ---------- Skeleton / Spinner ---------- */
.skeleton {
    background: linear-gradient(90deg, var(--bg-hover) 0%, var(--bg-secondary) 50%, var(--bg-hover) 100%);
    background-size: 200% 100%;
    animation: skeletonShimmer 1.4s ease-in-out infinite;
    border-radius: 6px;
}
.skeleton-text  { height: 12px; margin: 6px 0; }
.skeleton-line  { height: 14px; margin: 8px 0; }
.skeleton-block { height: 80px; }
.skeleton-circle{ width: 36px; height: 36px; border-radius: 50%; }
@keyframes skeletonShimmer {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

.spinner-sm { width: 14px; height: 14px; border-width: 2px; margin-right: 6px; }
.spinner-lg { width: 32px; height: 32px; border-width: 3px; }
.spinner-inline {
    display: inline-block;
    vertical-align: middle;
    margin-right: 0;
}

/* ---------- Tooltip ---------- */
.tip {
    position: relative;
    display: inline-flex;
}
.tip::after {
    content: attr(data-tip);
    position: absolute;
    bottom: calc(100% + 6px);
    left: 50%;
    transform: translateX(-50%) translateY(4px);
    background: var(--text-primary);
    color: var(--bg-card);
    padding: 4px 8px;
    border-radius: 6px;
    font-size: 0.74rem;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity .15s, transform .15s;
    z-index: 400;
}
.tip:hover::after,
.tip:focus-visible::after {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

/* ---------- Breadcrumb ---------- */
.crumbs {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.85rem;
    color: var(--text-muted);
    list-style: none;
    padding: 0;
}
.crumbs > li { display: inline-flex; align-items: center; gap: 6px; }
.crumbs > li:not(:last-child)::after {
    content: '/';
    color: var(--text-muted);
    margin: 0 2px;
}
.crumbs a { color: var(--text-secondary); }
.crumbs a:hover { color: var(--accent); }
.crumbs > li:last-child { color: var(--text-primary); font-weight: 500; }

/* ---------- File uploader ---------- */
.uploader {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 10px;
    padding: 28px 20px;
    border: 1.5px dashed var(--border-light);
    border-radius: 12px;
    background: var(--bg-secondary);
    color: var(--text-secondary);
    text-align: center;
    cursor: pointer;
    transition: all var(--transition);
}
.uploader:hover, .uploader.drag-over {
    border-color: var(--accent);
    background: var(--accent-soft);
    color: var(--accent);
}
.uploader-icon { font-size: 1.6rem; line-height: 1; }
.uploader-hint { font-size: 0.8rem; color: var(--text-muted); }

/* ---------- Modal helpers (Sample D 风格变体) ---------- */
.modal-icon {
    width: 44px; height: 44px;
    border-radius: 12px;
    display: inline-flex; align-items: center; justify-content: center;
    margin-bottom: 14px;
    flex-shrink: 0;
}
.modal-icon svg { width: 22px; height: 22px; }
.modal-icon.info    { background: var(--blue-soft);  color: var(--blue); }
.modal-icon.success { background: var(--green-soft); color: var(--green); }
.modal-icon.warning { background: var(--amber-soft); color: var(--yellow); }
.modal-icon.danger  { background: var(--red-soft);   color: var(--red); }
.modal-desc { font-size: 0.9rem; color: var(--text-secondary); line-height: 1.55; margin-top: -8px; margin-bottom: 18px; }

/* ---------- Tabs (Sample D 主标签 + 子 pill) ---------- */
.tabs-pill {
    display: inline-flex;
    gap: 4px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: 99px;
    padding: 3px;
}
.tabs-pill > .tab,
.tabs-pill > button {
    border: none; background: transparent;
    padding: 5px 14px;
    font-size: 0.83rem;
    color: var(--text-secondary);
    border-radius: 999px;
    cursor: pointer;
    transition: all var(--transition);
}
.tabs-pill > *:hover { color: var(--text-primary); }
.tabs-pill > *.active {
    background: var(--bg-card);
    color: var(--text-primary);
    font-weight: 600;
    box-shadow: var(--shadow-sm);
}

/* ---------- 深色模式下 chip 移除按钮 hover 兼容 ---------- */
:root[data-theme="dark"] .chip > .chip-remove:hover { background: rgba(255,255,255,.08); }
@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) .chip > .chip-remove:hover { background: rgba(255,255,255,.08); }
}

/* ---------- 主题切换按钮 ---------- */
.theme-toggle {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 5px 10px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--text-secondary);
    cursor: pointer;
    font-size: 0.82rem;
    transition: all var(--transition);
}
.theme-toggle:hover { color: var(--text-primary); border-color: var(--border-light); background: var(--bg-hover); }
.theme-toggle svg { width: 14px; height: 14px; }

/* ═══════════════════════════════════════════════════════
   霓虹浪潮 · 多色拼接覆盖
   ═══════════════════════════════════════════════════════ */

/* 主内容区多彩背景 */
.main-content {
    background: var(--bg-primary);
    background-image:
        radial-gradient(ellipse at 0% 0%, var(--accent-dim) 0%, transparent 50%),
        radial-gradient(ellipse at 100% 100%, var(--accent-4-dim) 0%, transparent 40%),
        radial-gradient(ellipse at 80% 10%, var(--accent-2-dim) 0%, transparent 35%);
}

/* sidebar 多彩导航项 */
.nav-group:nth-child(1) .nav-group-title .nav-icon { color: var(--accent); }
.nav-group:nth-child(2) .nav-group-title .nav-icon { color: var(--accent-2); }
.nav-group:nth-child(3) .nav-group-title .nav-icon { color: var(--accent-3); }

/* 导航子项彩色 hover */
.nav-item.nav-sub:nth-child(1):hover { border-left: 3px solid var(--accent); background: var(--accent-dim); }
.nav-item.nav-sub:nth-child(2):hover { border-left: 3px solid var(--accent-2); background: var(--accent-2-dim); }
.nav-item.nav-sub:nth-child(3):hover { border-left: 3px solid var(--accent-3); background: var(--accent-3-dim); }
.nav-item.nav-sub:nth-child(4):hover { border-left: 3px solid var(--accent-4); background: var(--accent-4-dim); }
.nav-item.nav-sub:nth-child(5):hover { border-left: 3px solid var(--accent-5); background: var(--accent-5-dim); }

/* 导航激活项彩色 */
.nav-item.nav-sub.active:nth-child(1) { color: var(--accent); }
.nav-item.nav-sub.active:nth-child(2) { color: var(--accent-2); }
.nav-item.nav-sub.active:nth-child(3) { color: var(--accent-3); }
.nav-item.nav-sub.active:nth-child(4) { color: var(--accent-4); }
.nav-item.nav-sub.active:nth-child(5) { color: var(--accent-5); }

/* 统计卡片彩色左边框 */
.dash-stat:nth-child(1) { border-left: 3px solid var(--accent); }
.dash-stat:nth-child(2) { border-left: 3px solid var(--accent-2); }
.dash-stat:nth-child(3) { border-left: 3px solid var(--accent-3); }
.dash-stat:nth-child(4) { border-left: 3px solid var(--accent-4); }

/* 课题板块彩色标签 */
.tag-accent { background: var(--accent-dim); color: var(--accent); }
.tag-green  { background: var(--accent-5-dim); color: var(--accent-5); }
.tag-yellow { background: var(--accent-3-dim); color: var(--accent-3); }
.tag-purple { background: var(--purple-dim); color: var(--purple); }
.tag-orange { background: var(--accent-3-dim); color: var(--accent-3); }
.tag-blue   { background: var(--accent-2-dim); color: var(--accent-2); }
.tag-red    { background: var(--accent-4-dim); color: var(--accent-4); }

/* 按钮彩色变体 */
.btn-primary { background: linear-gradient(135deg, var(--accent), var(--accent-3), var(--accent-5)); }
.btn-primary:hover { background: linear-gradient(135deg, var(--accent-hover), #db2777, var(--accent-5)); }

/* 卡片 hover 彩色光晕 */
.club-card:hover, .skill-card:hover { box-shadow: 0 4px 20px var(--accent-glow); }

/* 顶部栏多彩底线 */
.top-bar { border-bottom: 3px solid transparent;
    border-image: linear-gradient(90deg, var(--accent), var(--accent-3), var(--accent-5), var(--accent-2)) 1; }

/* sidebar logo 多彩 */
.logo-mark svg rect { fill: url(#brand-grad) !important; }

/* topic board 选择器多彩 */
.board-chip:nth-child(1),.board-chip:nth-child(7n+1) { background: var(--accent-dim); color: var(--accent); }
.board-chip:nth-child(2),.board-chip:nth-child(7n+2) { background: var(--accent-2-dim); color: var(--accent-2); }
.board-chip:nth-child(3),.board-chip:nth-child(7n+3) { background: var(--accent-3-dim); color: var(--accent-3); }
.board-chip:nth-child(4),.board-chip:nth-child(7n+4) { background: var(--accent-4-dim); color: var(--accent-4); }
.board-chip:nth-child(5),.board-chip:nth-child(7n+5) { background: var(--accent-5-dim); color: var(--accent-5); }
.board-chip:nth-child(6),.board-chip:nth-child(7n+6) { background: var(--purple-dim); color: var(--purple); }
.board-chip:nth-child(7),.board-chip:nth-child(7n)   { background: var(--blue-soft); color: var(--blue); }
