/* ── Theme tokens ─────────────────────────────────────────────────────────── */
:root {
    --ts-bg:          #0f0f0f;
    --ts-bg-raised:   #1a1a1a;
    --ts-bg-card:     #1f1f1f;
    --ts-bg-panel:    #141414;
    --ts-bg-input:    #111;
    --ts-bg-chip:     #2a2a2a;
    --ts-bg-hover:    #252525;
    --ts-bg-snippet:  #111;

    --ts-text:        #e8e8e8;
    --ts-text-card:   #ccc;
    --ts-text-sub:    #bbb;
    --ts-text-muted:  #888;
    --ts-text-dim:    #666;
    --ts-text-dimmer: #555;
    --ts-text-faint:  #444;
    --ts-text-barely: #333;

    --ts-border:        #2e2e2e;
    --ts-border-mid:    #2a2a2a;
    --ts-border-sub:    #1e1e1e;
    --ts-border-strong: #3a3a3a;
    --ts-border-faint:  #252525;

    --ts-accent:       #e05c1a;
    --ts-accent-h:     #ff7a3d;
    --ts-accent-press: #c44d13;
    --ts-accent-bg:    rgba(224,92,26,.08);

    --ts-danger:  #f87171;
    --ts-success: #4ade80;
    --ts-warn:    #facc15;
    --ts-code:    #f59e42;

    --ts-footer-disc: #444;
}

[data-theme="light"] {
    --ts-bg:          #f4f4f5;
    --ts-bg-raised:   #ffffff;
    --ts-bg-card:     #f9f9fa;
    --ts-bg-panel:    #e8e8ea;
    --ts-bg-input:    #ffffff;
    --ts-bg-chip:     #e4e4e7;
    --ts-bg-hover:    #d4d4d8;
    --ts-bg-snippet:  #f0f0f2;

    --ts-text:        #18181b;
    --ts-text-card:   #3f3f46;
    --ts-text-sub:    #52525b;
    --ts-text-muted:  #71717a;
    --ts-text-dim:    #a1a1aa;
    --ts-text-dimmer: #a1a1aa;
    --ts-text-faint:  #b4b4bc;
    --ts-text-barely: #d4d4d8;

    --ts-border:        #d4d4d8;
    --ts-border-mid:    #e4e4e7;
    --ts-border-sub:    #f4f4f5;
    --ts-border-strong: #a1a1aa;
    --ts-border-faint:  #e4e4e7;

    --ts-accent:       #c44d13;
    --ts-accent-h:     #e05c1a;
    --ts-accent-press: #a33d0e;
    --ts-accent-bg:    rgba(196,77,19,.1);

    --ts-danger:  #dc2626;
    --ts-success: #16a34a;
    --ts-warn:    #ca8a04;
    --ts-code:    #c44d13;

    --ts-footer-disc: #71717a;
}

[data-theme="hc-dark"] {
    --ts-bg:          #000;
    --ts-bg-raised:   #0a0a0a;
    --ts-bg-card:     #111;
    --ts-bg-panel:    #050505;
    --ts-bg-input:    #000;
    --ts-bg-chip:     #1a1a1a;
    --ts-bg-hover:    #222;
    --ts-bg-snippet:  #000;

    --ts-text:        #fff;
    --ts-text-card:   #fff;
    --ts-text-sub:    #e0e0e0;
    --ts-text-muted:  #c0c0c0;
    --ts-text-dim:    #a0a0a0;
    --ts-text-dimmer: #808080;
    --ts-text-faint:  #606060;
    --ts-text-barely: #404040;

    --ts-border:        #fff;
    --ts-border-mid:    #ccc;
    --ts-border-sub:    #888;
    --ts-border-strong: #fff;
    --ts-border-faint:  #555;

    --ts-accent:       #ff6a00;
    --ts-accent-h:     #ff8833;
    --ts-accent-press: #dd5500;
    --ts-accent-bg:    rgba(255,106,0,.15);

    --ts-danger:  #ff4444;
    --ts-success: #00e060;
    --ts-warn:    #ffee00;
    --ts-code:    #ff8833;

    --ts-footer-disc: #a0a0a0;
}

[data-theme="hc-light"] {
    --ts-bg:          #fff;
    --ts-bg-raised:   #fff;
    --ts-bg-card:     #f0f0f0;
    --ts-bg-panel:    #e0e0e0;
    --ts-bg-input:    #fff;
    --ts-bg-chip:     #d0d0d0;
    --ts-bg-hover:    #c0c0c0;
    --ts-bg-snippet:  #f0f0f0;

    --ts-text:        #000;
    --ts-text-card:   #000;
    --ts-text-sub:    #111;
    --ts-text-muted:  #333;
    --ts-text-dim:    #555;
    --ts-text-dimmer: #555;
    --ts-text-faint:  #777;
    --ts-text-barely: #999;

    --ts-border:        #000;
    --ts-border-mid:    #222;
    --ts-border-sub:    #444;
    --ts-border-strong: #000;
    --ts-border-faint:  #777;

    --ts-accent:       #b33000;
    --ts-accent-h:     #cc3a00;
    --ts-accent-press: #8a2500;
    --ts-accent-bg:    rgba(179,48,0,.12);

    --ts-danger:  #cc0000;
    --ts-success: #006600;
    --ts-warn:    #886600;
    --ts-code:    #8a2500;

    --ts-footer-disc: #555;
}

@media (prefers-color-scheme: light) {
    :root:not([data-theme]) {
        --ts-bg:          #f4f4f5;
        --ts-bg-raised:   #ffffff;
        --ts-bg-card:     #f9f9fa;
        --ts-bg-panel:    #e8e8ea;
        --ts-bg-input:    #ffffff;
        --ts-bg-chip:     #e4e4e7;
        --ts-bg-hover:    #d4d4d8;
        --ts-bg-snippet:  #f0f0f2;

        --ts-text:        #18181b;
        --ts-text-card:   #3f3f46;
        --ts-text-sub:    #52525b;
        --ts-text-muted:  #71717a;
        --ts-text-dim:    #a1a1aa;
        --ts-text-dimmer: #a1a1aa;
        --ts-text-faint:  #b4b4bc;
        --ts-text-barely: #d4d4d8;

        --ts-border:        #d4d4d8;
        --ts-border-mid:    #e4e4e7;
        --ts-border-sub:    #f4f4f5;
        --ts-border-strong: #a1a1aa;
        --ts-border-faint:  #e4e4e7;

        --ts-accent:       #c44d13;
        --ts-accent-h:     #e05c1a;
        --ts-accent-press: #a33d0e;
        --ts-accent-bg:    rgba(196,77,19,.1);

        --ts-danger:  #dc2626;
        --ts-success: #16a34a;
        --ts-warn:    #ca8a04;
        --ts-code:    #c44d13;

        --ts-footer-disc: #71717a;
    }
}

/* ── Base ─────────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
    background: var(--ts-bg);
    color: var(--ts-text);
    min-height: 100vh;
}
body { display: flex; flex-direction: column; }
.ts-main { flex: 1; }

a { color: var(--ts-accent); }
a:hover { color: var(--ts-accent-h); }
kbd {
    display: inline-block;
    padding: 2px 6px;
    font-size: .8em;
    background: var(--ts-bg-chip);
    border: 1px solid var(--ts-border-strong);
    border-radius: 4px;
    color: var(--ts-text);
}
code {
    font-family: 'Consolas', 'Fira Code', monospace;
    font-size: .85em;
    color: var(--ts-code);
}

/* ── Layout container ─────────────────────────────────────────────────────── */
.ts-container {
    max-width: 900px;
    margin: 0 auto;
    padding: 2rem 1rem 7rem;
}

/* ── Header ───────────────────────────────────────────────────────────────── */
.ts-header { margin-bottom: 1.75rem; }
.ts-header h1 {
    margin: 0 0 .25rem;
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: -.5px;
    color: var(--ts-text);
}
.ts-header p { margin: 0; color: var(--ts-text-muted); font-size: .95rem; }

/* ── Cards ────────────────────────────────────────────────────────────────── */
.ts-card {
    background: var(--ts-bg-raised);
    border: 1px solid var(--ts-border);
    border-radius: 10px;
    margin-bottom: 1rem;
    overflow: hidden;
}
.ts-card--chart { margin-top: 1rem; }

.ts-card-header {
    padding: .75rem 1rem;
    border-bottom: 1px solid var(--ts-border-mid);
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: .9rem;
    color: var(--ts-text-sub);
}
.ts-card-header strong { color: var(--ts-text); }
.ts-chevron { font-size: .75rem; color: var(--ts-text-dim); }

.ts-card-body { padding: 1rem; }

/* ── Steps list ───────────────────────────────────────────────────────────── */
.ts-steps {
    margin: 0 0 1rem 1.25rem;
    padding: 0;
    font-size: .9rem;
    line-height: 1.7;
    color: var(--ts-text-sub);
}
.ts-steps li { margin-bottom: .25rem; }

/* ── Snippet ──────────────────────────────────────────────────────────────── */
.ts-snippet-wrap { position: relative; }
.ts-snippet {
    margin: 0;
    padding: .9rem 1rem;
    background: var(--ts-bg-snippet);
    border: 1px solid var(--ts-border-strong);
    border-radius: 6px;
    font-family: 'Consolas', 'Fira Code', monospace;
    font-size: .78rem;
    line-height: 1.5;
    color: #a8d8a8;
    overflow-x: auto;
    white-space: pre;
    tab-size: 2;
}
.ts-copy-btn {
    position: absolute;
    top: .5rem;
    right: .5rem;
    padding: .25rem .65rem;
    font-size: .75rem;
    background: var(--ts-bg-chip);
    color: var(--ts-text-card);
    border: 1px solid var(--ts-border-strong);
    border-radius: 4px;
    cursor: pointer;
    transition: background .15s, color .15s;
}
.ts-copy-btn:hover { background: var(--ts-bg-hover); color: var(--ts-text); }

/* ── Drop zone ────────────────────────────────────────────────────────────── */
.ts-drop-zone {
    display: block;
    position: relative;
    border: 2px dashed var(--ts-border-strong);
    border-radius: 8px;
    padding: 2.5rem 1rem;
    text-align: center;
    cursor: pointer;
    transition: border-color .2s, background .2s;
}
.ts-drop-zone:hover,
.ts-drop-zone--active { border-color: var(--ts-accent); background: var(--ts-accent-bg); }
.ts-drop-zone input[type=file] {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
    width: 100%;
    height: 100%;
}
.ts-drop-label {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .4rem;
    pointer-events: none;
    font-size: .95rem;
    color: var(--ts-text-muted);
}
.ts-drop-icon { font-size: 2rem; }
.ts-drop-sub { font-size: .8rem; color: var(--ts-text-dim); }

/* ── Messages ─────────────────────────────────────────────────────────────── */
.ts-messages {
    background: var(--ts-bg-raised);
    border: 1px solid var(--ts-border);
    border-radius: 8px;
    padding: .75rem 1rem;
    margin-bottom: 1rem;
    font-size: .85rem;
}
.ts-msg { padding: .2rem 0; }
.ts-msg--error { color: var(--ts-danger); }
.ts-msg--warn  { color: var(--ts-warn); }
.ts-msg-dismiss {
    margin-top: .5rem;
    background: none;
    border: 1px solid var(--ts-border-strong);
    border-radius: 4px;
    color: var(--ts-text-muted);
    font-size: .8rem;
    padding: .2rem .6rem;
    cursor: pointer;
}
.ts-msg-dismiss:hover { color: var(--ts-text); border-color: var(--ts-text-muted); }

/* ── Player pills ─────────────────────────────────────────────────────────── */
.ts-pills { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; }
.ts-pill {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    background: var(--ts-bg-chip);
    border: 1px solid var(--ts-border-strong);
    border-radius: 999px;
    padding: .3rem .75rem;
    font-size: .85rem;
    color: var(--ts-text-card);
}
.ts-pill-remove {
    background: none;
    border: none;
    color: var(--ts-text-dim);
    font-size: 1rem;
    line-height: 1;
    cursor: pointer;
    padding: 0;
    margin: 0;
}
.ts-pill-remove:hover { color: var(--ts-danger); }
.ts-pill-name { white-space: nowrap; }
.ts-pill-group-input {
    background: transparent;
    border: none;
    border-bottom: 1px dashed var(--ts-border-strong);
    color: var(--ts-text-muted);
    font-size: .78rem;
    padding: .1rem .25rem;
    width: 7rem;
    min-width: 0;
    outline: none;
    font-family: inherit;
}
.ts-pill-group-input:focus { border-bottom-color: var(--ts-accent); color: var(--ts-text); }
.ts-pill-group-input::placeholder { color: var(--ts-text-dim); }
.ts-pill-hint { margin: .5rem 0 0; font-size: .75rem; color: var(--ts-text-dim); }

/* ── Series toggles ───────────────────────────────────────────────────────── */
.ts-series-toggles {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .4rem .75rem;
    margin-top: 1rem;
    padding-top: .75rem;
    border-top: 1px solid var(--ts-border-mid);
}
.ts-series-label {
    flex-basis: 100%;
    font-size: .72rem;
    color: var(--ts-text-dim);
    text-transform: uppercase;
    letter-spacing: .06em;
}
.ts-series-toggle {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    font-size: .82rem;
    color: var(--ts-text-card);
    cursor: pointer;
    user-select: none;
    transition: color .15s;
}
.ts-series-toggle input[type="checkbox"] { cursor: pointer; accent-color: var(--ts-accent); }
.ts-series-toggle--hidden { color: var(--ts-text-dimmer); }

/* ── Search bars ──────────────────────────────────────────────────────────── */
.ts-search-section { display: flex; flex-direction: column; gap: .6rem; }
.ts-search-row { display: flex; flex-direction: column; gap: .4rem; }
.ts-search-group { display: flex; gap: .5rem; align-items: center; }
.ts-input {
    flex: 1;
    background: var(--ts-bg-input);
    border: 1px solid var(--ts-border-strong);
    border-radius: 6px;
    color: var(--ts-text);
    font-size: .9rem;
    padding: .5rem .75rem;
    outline: none;
    transition: border-color .15s;
}
.ts-input:focus { border-color: var(--ts-accent); }
.ts-input:disabled { opacity: .5; }

.ts-spinner {
    display: inline-block;
    width: 14px;
    height: 14px;
    border: 2px solid rgba(128,128,128,.3);
    border-top-color: var(--ts-text);
    border-radius: 50%;
    animation: spin .6s linear infinite;
    vertical-align: middle;
}
@keyframes spin { to { transform: rotate(360deg); } }

.ts-candidates {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem;
    align-items: center;
    padding: .4rem .2rem;
    border-left: 2px solid var(--ts-accent);
    padding-left: .75rem;
}
.ts-candidates-label { font-size: .78rem; color: var(--ts-text-muted); width: 100%; }
.ts-candidate {
    display: flex;
    align-items: baseline;
    gap: .4rem;
    background: var(--ts-bg-card);
    border: 1px solid var(--ts-border-strong);
    border-radius: 5px;
    color: var(--ts-text-card);
    font-size: .85rem;
    padding: .3rem .7rem;
    cursor: pointer;
    transition: border-color .15s, background .15s;
}
.ts-candidate:hover { border-color: var(--ts-accent); background: var(--ts-accent-bg); }
.ts-candidate-name { font-weight: 500; }
.ts-candidate-platform { font-size: .75rem; color: var(--ts-accent); }
.ts-candidate-id { font-size: .75rem; color: var(--ts-text-dim); font-family: monospace; }

.ts-bar-error { font-size: .82rem; color: var(--ts-danger); padding: .2rem .1rem; }

/* ── Utility buttons ──────────────────────────────────────────────────────── */
.ts-btn {
    padding: .3rem .75rem;
    border-radius: 5px;
    font-size: .82rem;
    cursor: pointer;
    border: 1px solid transparent;
    transition: background .15s;
}
.ts-btn--ghost { background: none; border-color: var(--ts-border-strong); color: var(--ts-text-muted); }
.ts-btn--ghost:hover { border-color: var(--ts-danger); color: var(--ts-danger); }

.ts-btn--primary {
    background: var(--ts-accent);
    border-color: var(--ts-accent);
    color: #fff;
    font-weight: 600;
    min-width: 70px;
    justify-content: center;
    display: inline-flex;
    align-items: center;
    gap: .35rem;
}
.ts-btn--primary:hover:not(:disabled) { background: var(--ts-accent-press); border-color: var(--ts-accent-press); }
.ts-btn--primary:disabled { opacity: .45; cursor: not-allowed; }

.ts-btn--icon {
    background: none;
    border-color: var(--ts-border-mid);
    color: var(--ts-text-dim);
    font-size: 1.1rem;
    line-height: 1;
    padding: .3rem .55rem;
}
.ts-btn--icon:hover { border-color: var(--ts-danger); color: var(--ts-danger); }

.ts-btn--add {
    align-self: flex-start;
    background: none;
    border-color: var(--ts-border-strong);
    color: var(--ts-text-muted);
    margin-top: .2rem;
    font-size: .85rem;
}
.ts-btn--add:hover { border-color: var(--ts-accent); color: var(--ts-accent); }

.ts-card--dimmed { opacity: .75; }
.ts-card--dimmed:hover { opacity: 1; transition: opacity .2s; }

.ts-collapsible { cursor: pointer; user-select: none; }
.ts-muted { color: var(--ts-text-dim); font-weight: 400; font-size: .85em; }

/* ── Sidebar (fixed overlay) ─────────────────────────────────────────────── */
.ts-sb-backdrop { display: none; }
@media (max-width: 700px) {
    .ts-sb-backdrop {
        display: block;
        position: fixed;
        inset: 0;
        background: rgba(0,0,0,.55);
        z-index: 999;
    }
}

.ts-sb-wrapper {
    position: fixed;
    right: 0;
    top: 52px;
    bottom: 80px;
    width: 290px;
    max-width: 90vw;
    z-index: 1000;
    transform: translateX(100%);
    transition: transform .25s ease;
    overflow: visible;
}
.ts-sb-wrapper--open { transform: translateX(0); }

/* Full-height overlay on mobile */
@media (max-width: 700px) {
    .ts-sb-wrapper { top: 0; bottom: 0; }
}

/* Always visible on wide screens */
@media (min-width: 1401px) {
    .ts-sb-wrapper { transform: translateX(0) !important; transition: none; }
    .ts-sb-tab { display: none !important; }
    .ts-sb-backdrop { display: none !important; }
}

.ts-sb-tab {
    position: absolute;
    left: -32px;
    top: 50%;
    transform: translateY(-50%);
    width: 32px;
    min-height: 80px;
    padding: .5rem .3rem;
    background: var(--ts-bg-raised);
    border: 1px solid var(--ts-border-strong);
    border-right: none;
    border-radius: 6px 0 0 6px;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: .3rem;
    color: var(--ts-text-muted);
    font-size: .7rem;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    transition: color .15s, background .15s;
}
.ts-sb-tab:hover { color: var(--ts-text); background: var(--ts-bg-hover); }
.ts-sb-tab-count {
    background: var(--ts-accent);
    color: #fff;
    border-radius: 999px;
    font-size: .65rem;
    font-weight: 700;
    padding: .1rem .25rem;
    writing-mode: horizontal-tb;
    min-width: 16px;
    text-align: center;
}

.ts-sb-panel {
    position: absolute;
    inset: 0;
    background: var(--ts-bg-panel);
    border-left: 1px solid var(--ts-border);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.ts-sb-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: .75rem 1rem;
    border-bottom: 1px solid var(--ts-border-mid);
    flex-shrink: 0;
}
.ts-sb-title {
    font-size: .85rem;
    font-weight: 600;
    color: var(--ts-text-card);
    text-transform: uppercase;
    letter-spacing: .06em;
}
.ts-sb-header-actions { display: flex; gap: .4rem; }

.ts-sb-scroll {
    flex: 1;
    overflow-y: auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
}

.ts-sbtn {
    padding: .2rem .55rem;
    border-radius: 4px;
    font-size: .75rem;
    cursor: pointer;
    border: 1px solid transparent;
    transition: background .15s, color .15s, border-color .15s;
    background: none;
}
.ts-sbtn--ghost { border-color: var(--ts-border-strong); color: var(--ts-text-muted); }
.ts-sbtn--ghost:hover { border-color: var(--ts-text-muted); color: var(--ts-text-card); }
.ts-sbtn--danger:hover { border-color: var(--ts-danger); color: var(--ts-danger); }

.ts-sb-section-header {
    display: flex;
    align-items: center;
    gap: .4rem;
    padding: .4rem 1rem .3rem;
    background: var(--ts-bg-raised);
    border-top: 1px solid var(--ts-border-mid);
    border-bottom: 1px solid var(--ts-border-mid);
    flex-shrink: 0;
}
.ts-sb-section-name {
    flex: 1;
    background: transparent;
    border: none;
    border-bottom: 1px dashed var(--ts-border-strong);
    color: var(--ts-accent);
    font-size: .8rem;
    font-weight: 600;
    outline: none;
    padding: .1rem .2rem;
    font-family: inherit;
    letter-spacing: .03em;
    text-transform: uppercase;
}
.ts-sb-section-name:focus { border-bottom-color: var(--ts-accent); }
.ts-sb-section-remove {
    background: none;
    border: none;
    color: var(--ts-text-faint);
    font-size: .9rem;
    cursor: pointer;
    padding: 0 .1rem;
    line-height: 1;
}
.ts-sb-section-remove:hover { color: var(--ts-danger); }

.ts-sb-zone {
    padding: .4rem .6rem;
    min-height: 2.5rem;
    display: flex;
    flex-direction: column;
    gap: .4rem;
}
.ts-sb-drop-hint {
    font-size: .75rem;
    color: var(--ts-text-barely);
    text-align: center;
    padding: .5rem;
    border: 1px dashed var(--ts-border-faint);
    border-radius: 6px;
}

/* New-section drop zone */
.ts-sb-new-section-zone {
    margin: .5rem .6rem .6rem;
    border: 2px dashed var(--ts-border-mid);
    border-radius: 6px;
    padding: .55rem .6rem;
    text-align: center;
    cursor: default;
    transition: border-color .2s, background .2s;
    flex-shrink: 0;
}
.ts-sb-new-section-zone--active {
    border-color: var(--ts-accent);
    background: var(--ts-accent-bg);
}
.ts-sb-new-section-hint {
    font-size: .71rem;
    color: var(--ts-text-dimmer);
    line-height: 1.4;
    pointer-events: none;
}

.ts-sb-card {
    background: var(--ts-bg-card);
    border: 1px solid var(--ts-border);
    border-radius: 7px;
    padding: .55rem .65rem .45rem;
    display: flex;
    flex-direction: column;
    gap: .35rem;
    cursor: grab;
    transition: border-color .15s;
    user-select: none;
}
.ts-sb-card:hover { border-color: var(--ts-border-strong); }
.ts-sb-card:active { cursor: grabbing; }
.ts-sb-card--selected {
    border-color: var(--ts-accent) !important;
    background: var(--ts-accent-bg);
}

.ts-sb-card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .4rem;
}
.ts-sb-card-name {
    font-size: .8rem;
    color: var(--ts-text-card);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
    min-width: 0;
}
.ts-sb-card-actions { display: flex; align-items: center; gap: .25rem; flex-shrink: 0; }
.ts-sb-color {
    width: 20px;
    height: 20px;
    border: none;
    border-radius: 3px;
    padding: 0;
    cursor: pointer;
    background: none;
}
.ts-sb-color::-webkit-color-swatch-wrapper { padding: 0; }
.ts-sb-color::-webkit-color-swatch { border: none; border-radius: 3px; }
.ts-sb-remove {
    background: none;
    border: none;
    color: var(--ts-text-faint);
    font-size: .95rem;
    cursor: pointer;
    padding: 0;
    line-height: 1;
}
.ts-sb-remove:hover { color: var(--ts-danger); }

.ts-sb-move-select {
    width: 100%;
    background: var(--ts-bg-panel);
    border: 1px solid var(--ts-border);
    border-radius: 4px;
    color: var(--ts-text-muted);
    font-size: .75rem;
    padding: .2rem .35rem;
    cursor: pointer;
    outline: none;
}
.ts-sb-move-select:focus { border-color: var(--ts-accent); }

.ts-sb-chars { display: flex; flex-wrap: wrap; gap: .25rem .35rem; }
.ts-sb-char {
    font-size: .73rem;
    color: var(--ts-text-card);
    cursor: pointer;
    padding: .1rem .3rem;
    border-radius: 3px;
    background: var(--ts-bg-chip);
    user-select: none;
    transition: color .12s, background .12s, filter .12s;
}
.ts-sb-char:hover { background: var(--ts-bg-hover); color: var(--ts-text); }
.ts-sb-char--off { color: var(--ts-text-dimmer); background: var(--ts-bg-raised); filter: grayscale(1); }

.ts-sb-char-wrap { position: relative; }
.ts-sb-char-menu-btn {
    background: none;
    border: 1px solid var(--ts-border);
    border-radius: 4px;
    color: var(--ts-text-muted);
    font-size: .73rem;
    cursor: pointer;
    padding: .2rem .45rem;
    width: 100%;
    text-align: left;
    transition: border-color .15s, color .15s;
}
.ts-sb-char-menu-btn:hover { border-color: var(--ts-border-strong); color: var(--ts-text-card); }
.ts-sb-char-arrow { font-size: .6rem; }

.ts-sb-char-menu {
    position: absolute;
    left: 0; right: 0;
    top: calc(100% + 2px);
    background: var(--ts-bg-raised);
    border: 1px solid var(--ts-border-strong);
    border-radius: 5px;
    z-index: 10;
    max-height: 180px;
    overflow-y: auto;
    box-shadow: 0 4px 12px rgba(0,0,0,.4);
}
.ts-sb-char-item {
    padding: .35rem .65rem;
    font-size: .78rem;
    color: var(--ts-text-card);
    cursor: pointer;
    user-select: none;
    transition: background .1s, color .1s, filter .1s;
}
.ts-sb-char-item:hover { background: var(--ts-bg-hover); color: var(--ts-text); }
.ts-sb-char-item--off { color: var(--ts-text-dimmer); filter: grayscale(1); }
.ts-sb-char-item--off:hover { background: var(--ts-bg-hover); color: var(--ts-text-muted); }

/* ── Matchups & win/loss ─────────────────────────────────────────────────── */
.ts-mu-selectors {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-bottom: 1rem;
}
.ts-mu-selector {
    display: flex;
    flex-direction: column;
    gap: .3rem;
    flex: 1;
    min-width: 200px;
}
.ts-mu-selector > span {
    font-size: .72rem;
    color: var(--ts-text-muted);
    text-transform: uppercase;
    letter-spacing: .05em;
}
.ts-mu-selector-controls {
    display: flex;
    gap: .4rem;
    align-items: center;
}
.ts-mu-selector-controls select { flex: 1; }
.ts-mu-bar-color {
    width: 28px;
    height: 34px;
    border: 1px solid var(--ts-border-strong);
    border-radius: 4px;
    padding: 1px;
    cursor: pointer;
    background: none;
    flex-shrink: 0;
}
.ts-mu-bar-color::-webkit-color-swatch-wrapper { padding: 0; }
.ts-mu-bar-color::-webkit-color-swatch { border: none; border-radius: 2px; }
.ts-mu-selector select {
    background: var(--ts-bg-input);
    border: 1px solid var(--ts-border-strong);
    border-radius: 6px;
    color: var(--ts-text);
    font-size: .9rem;
    padding: .5rem .65rem;
    outline: none;
    cursor: pointer;
}
.ts-mu-selector select:focus { border-color: var(--ts-accent); }

.ts-mu-hint { margin: 0; font-size: .85rem; color: var(--ts-text-dim); }
.ts-mu-chart { margin-bottom: 1rem; }

.ts-mu-cols {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}
.ts-mu-cols--two { grid-template-columns: repeat(2, 1fr); }

.ts-mu-col {
    background: var(--ts-bg-panel);
    border: 1px solid var(--ts-border-mid);
    border-radius: 8px;
    overflow: hidden;
}
.ts-mu-col-head {
    padding: .65rem .85rem;
    border-bottom: 1px solid var(--ts-border-mid);
    background: var(--ts-bg-raised);
}
.ts-mu-col-title {
    display: block;
    font-size: .9rem;
    font-weight: 600;
    color: var(--ts-text);
    margin-bottom: .35rem;
}
.ts-mu-extremes { display: flex; flex-wrap: wrap; gap: .25rem .75rem; font-size: .76rem; }
.ts-mu-worst { color: var(--ts-danger); }
.ts-mu-best  { color: var(--ts-success); }

.ts-mu-rows { max-height: 340px; overflow-y: auto; }
.ts-mu-row {
    display: grid;
    grid-template-columns: 1fr auto auto;
    align-items: center;
    gap: .5rem;
    padding: .35rem .85rem;
    font-size: .83rem;
    border-bottom: 1px solid var(--ts-border-sub);
}
.ts-mu-row:last-child { border-bottom: none; }
.ts-mu-char { color: var(--ts-text-card); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ts-mu-record { color: var(--ts-text-muted); font-variant-numeric: tabular-nums; font-family: 'Consolas', monospace; }
.ts-mu-sep { color: var(--ts-text-dimmer); margin: 0 1px; }
.ts-mu-rate {
    color: var(--ts-text);
    font-weight: 600;
    min-width: 3rem;
    text-align: right;
    font-variant-numeric: tabular-nums;
}

/* ── Blazor loading / error ───────────────────────────────────────────────── */
.loading-progress {
    position: absolute;
    display: block;
    width: 8rem;
    height: 8rem;
    inset: 20vh 0 auto 0;
    margin: 0 auto;
}
.loading-progress circle {
    fill: none;
    stroke: var(--ts-border-mid);
    stroke-width: 0.6rem;
    transform-origin: 50% 50%;
    transform: rotate(-90deg);
}
.loading-progress circle:last-child {
    stroke: var(--ts-accent);
    stroke-dasharray: calc(3.141 * var(--blazor-load-percentage, 0%) * 0.8), 500%;
    transition: stroke-dasharray 0.05s ease-in-out;
}
.loading-progress-text {
    position: absolute;
    text-align: center;
    font-weight: bold;
    inset: calc(20vh + 3.25rem) 0 auto .2rem;
}
.loading-progress-text:after { content: var(--blazor-load-percentage-text, "Loading"); }

#blazor-error-ui {
    background: #7f1d1d;
    color: #fecaca;
    bottom: 0; left: 0;
    width: 100%;
    padding: .6rem 1.25rem;
    position: fixed;
    display: none;
    z-index: 1000;
    font-size: .9rem;
}
#blazor-error-ui a { color: #fca5a5; }
#blazor-error-ui .dismiss { cursor: pointer; float: right; }

/* ── Nav ──────────────────────────────────────────────────────────────────── */
.ts-nav {
    position: relative;
    z-index: 1100;
    background: var(--ts-bg-panel);
    border-bottom: 1px solid var(--ts-border-mid);
    padding: 0 1.5rem;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 2rem;
    height: 52px;
    flex-shrink: 0;
}
.ts-nav-brand {
    font-size: 1rem;
    font-weight: 700;
    color: var(--ts-text);
    text-decoration: none;
    letter-spacing: -.3px;
    flex-shrink: 0;
}
.ts-nav-brand:hover { color: var(--ts-accent); }
.ts-nav-links { display: flex; gap: 1.25rem; align-items: center; }
.ts-nav-link {
    color: var(--ts-text-muted);
    text-decoration: none;
    font-size: .875rem;
    transition: color .15s;
}
.ts-nav-link:hover { color: var(--ts-text-card); }
.ts-nav-link.active { color: var(--ts-accent); }

.ts-theme-select {
    margin-left: auto;
    background: var(--ts-bg-input);
    border: 1px solid var(--ts-border-strong);
    border-radius: 5px;
    color: var(--ts-text-muted);
    font-size: .78rem;
    padding: .25rem .5rem;
    cursor: pointer;
    outline: none;
    flex-shrink: 0;
}
.ts-theme-select:focus { border-color: var(--ts-accent); color: var(--ts-text); }

/* ── Footer ───────────────────────────────────────────────────────────────── */
.ts-footer {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 6px 1.5rem;
    border-top: 1px solid var(--ts-border-sub);
    font-size: .72rem;
    color: var(--ts-text-dim);
    background: var(--ts-bg-panel);
    z-index: 1100;
}
.ts-footer a { color: var(--ts-text-faint); }
.ts-footer a:hover { color: var(--ts-text-muted); }
.ts-footer-disclaimer {
    text-align: center;
    max-width: 560px;
    color: var(--ts-footer-disc);
    font-size: .68rem;
    line-height: 1.4;
}

/* ── Wide grid (chart + matchups side by side) ───────────────────────────── */
.ts-wide-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
    margin-top: 1rem;
}
.ts-wide-grid > .ts-card { margin-bottom: 0; }

@media (min-width: 1200px) {
    .ts-container { max-width: 1400px; }
    .ts-wide-grid { grid-template-columns: 3fr 2fr; align-items: start; }
}

/* ── Time filter ──────────────────────────────────────────────────────────── */
.ts-time-filters { display: flex; gap: .25rem; align-items: center; }
.ts-time-btn {
    padding: .15rem .45rem;
    font-size: .72rem;
    border-radius: 4px;
    border: 1px solid var(--ts-border-mid);
    background: none;
    color: var(--ts-text-dim);
    cursor: pointer;
    transition: all .15s;
}
.ts-time-btn:hover { border-color: var(--ts-border-strong); color: var(--ts-text-muted); }
.ts-time-btn--active { border-color: var(--ts-accent); color: var(--ts-accent); background: var(--ts-accent-bg); }

/* ── Recent players ───────────────────────────────────────────────────────── */
.ts-recent {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .3rem .5rem;
    padding-top: .5rem;
    border-top: 1px solid var(--ts-border-mid);
}
.ts-recent-label {
    font-size: .72rem;
    color: var(--ts-text-dimmer);
    text-transform: uppercase;
    letter-spacing: .05em;
    flex-shrink: 0;
}
.ts-recent-chip-wrap {
    position: relative;
    display: inline-flex;
    align-items: center;
}
.ts-recent-chip {
    padding: .2rem .55rem;
    font-size: .78rem;
    border-radius: 999px;
    border: 1px solid var(--ts-border);
    background: var(--ts-bg-raised);
    color: var(--ts-text-muted);
    cursor: pointer;
    transition: all .15s;
}
.ts-recent-chip:hover { border-color: var(--ts-accent); color: var(--ts-accent); background: var(--ts-accent-bg); }
.ts-recent-chip--selected { border-color: var(--ts-accent) !important; background: var(--ts-accent-bg) !important; color: var(--ts-accent) !important; }
.ts-recent-chip-del {
    display: none;
    position: absolute;
    left: -5px;
    top: -5px;
    width: 15px;
    height: 15px;
    font-size: .6rem;
    line-height: 1;
    background: var(--ts-bg-raised);
    border: 1px solid var(--ts-border-strong);
    border-radius: 50%;
    color: var(--ts-text-muted);
    cursor: pointer;
    padding: 0;
    align-items: center;
    justify-content: center;
    transition: color .15s, border-color .15s;
}
.ts-recent-chip-wrap:hover .ts-recent-chip-del { display: flex; }
.ts-recent-chip-del:hover { color: var(--ts-danger); border-color: var(--ts-danger); }

/* ── Player card main-character rating ───────────────────────────────────── */
.ts-sb-card-rating { display: flex; align-items: center; gap: .35rem; font-size: .75rem; }
.ts-sb-card-char { color: var(--ts-accent); font-weight: 600; }
.ts-sb-card-glicko { color: var(--ts-text-muted); font-variant-numeric: tabular-nums; font-family: 'Consolas', monospace; }

/* ── Color palette popup ──────────────────────────────────────────────────── */
.ts-sb-color-wrap {
    position: relative;
    display: inline-flex;
    align-items: center;
}
.ts-sb-color-btn {
    width: 16px;
    height: 16px;
    border-radius: 3px;
    border: 1px solid rgba(255,255,255,.2);
    padding: 0;
    cursor: pointer;
    flex-shrink: 0;
    transition: transform .1s;
}
.ts-sb-color-btn:hover { transform: scale(1.2); }
.ts-sb-color-palette {
    position: absolute;
    right: 0;
    top: calc(100% + 4px);
    background: var(--ts-bg-panel);
    border: 1px solid var(--ts-border-strong);
    border-radius: 6px;
    padding: 5px;
    display: grid;
    grid-template-columns: repeat(3, 20px);
    gap: 3px;
    z-index: 20;
    box-shadow: 0 4px 12px rgba(0,0,0,.4);
}
.ts-sb-palette-swatch {
    width: 20px;
    height: 20px;
    border-radius: 3px;
    border: 2px solid transparent;
    padding: 0;
    cursor: pointer;
    transition: transform .1s, border-color .1s;
}
.ts-sb-palette-swatch:hover { transform: scale(1.1); }
.ts-sb-palette-swatch--active { border-color: #fff; }

/* ── Sidebar card visibility toggle ──────────────────────────────────────── */
.ts-sb-card--hidden { opacity: .45; }
.ts-sb-visibility {
    background: none;
    border: 1px solid var(--ts-border-strong);
    border-radius: 3px;
    color: var(--ts-text-muted);
    font-size: .65rem;
    cursor: pointer;
    padding: 1px 4px;
    line-height: 1.3;
    transition: all .15s;
    white-space: nowrap;
}
.ts-sb-visibility:hover { border-color: var(--ts-accent); color: var(--ts-accent); }
.ts-sb-visibility--hidden { color: var(--ts-text-dimmer); border-color: var(--ts-border-mid); }
.ts-sb-visibility--hidden:hover { border-color: var(--ts-accent); color: var(--ts-accent); }

/* ── Char stat (menu dropdown inline) ────────────────────────────────────── */
.ts-sb-char-item { display: flex; justify-content: space-between; align-items: center; gap: .5rem; }
.ts-sb-char-stat { font-size: .68rem; color: var(--ts-text-dimmer); white-space: nowrap; flex-shrink: 0; font-variant-numeric: tabular-nums; }

/* ── Chart game counts ────────────────────────────────────────────────────── */
.ts-chart-counts {
    display: flex;
    flex-wrap: wrap;
    gap: .25rem .75rem;
    margin-top: .5rem;
    padding-top: .5rem;
    border-top: 1px solid var(--ts-border-mid);
    font-size: .75rem;
    color: var(--ts-text-muted);
}
.ts-chart-count strong { color: var(--ts-text-card); font-variant-numeric: tabular-nums; }

/* ── Custom date range ────────────────────────────────────────────────────── */
.ts-custom-range {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-bottom: .75rem;
    padding: .6rem .75rem;
    background: var(--ts-bg-input);
    border: 1px solid var(--ts-border-strong);
    border-radius: 6px;
}
.ts-custom-range label {
    display: flex;
    flex-direction: column;
    gap: .2rem;
    font-size: .72rem;
    color: var(--ts-text-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
}
.ts-custom-range input[type="datetime-local"] {
    background: var(--ts-bg-panel);
    border: 1px solid var(--ts-border-strong);
    border-radius: 4px;
    color: var(--ts-text);
    font-size: .82rem;
    padding: .3rem .5rem;
    outline: none;
    cursor: pointer;
    color-scheme: dark;
}
[data-theme="light"] .ts-custom-range input[type="datetime-local"],
[data-theme="hc-light"] .ts-custom-range input[type="datetime-local"] {
    color-scheme: light;
}
.ts-custom-range input[type="datetime-local"]:focus { border-color: var(--ts-accent); }

/* ── Sidebar wide-screen padding ─────────────────────────────────────────── */
@media (min-width: 1401px) {
    .ts-main--sb { padding-right: 300px; }
}

/* ── Star button in player card ──────────────────────────────────────────── */
.ts-sb-star {
    background: none;
    border: none;
    color: var(--ts-text-faint);
    font-size: .95rem;
    cursor: pointer;
    padding: 0;
    line-height: 1;
    transition: color .15s;
}
.ts-sb-star:hover  { color: var(--ts-warn); }
.ts-sb-star--on    { color: var(--ts-warn); }

/* ── Star on recent chips ────────────────────────────────────────────────── */
.ts-recent-chip-star {
    display: none;
    position: absolute;
    right: -5px;
    top: -5px;
    width: 15px;
    height: 15px;
    font-size: .58rem;
    line-height: 1;
    background: var(--ts-bg-raised);
    border: 1px solid var(--ts-border-strong);
    border-radius: 50%;
    color: var(--ts-text-muted);
    cursor: pointer;
    padding: 0;
    align-items: center;
    justify-content: center;
    transition: color .15s, border-color .15s;
}
.ts-recent-chip-wrap:hover .ts-recent-chip-star { display: flex; }
.ts-recent-chip-star:hover   { color: var(--ts-warn); border-color: var(--ts-warn); }
.ts-recent-chip-star--on     { color: var(--ts-warn); border-color: var(--ts-warn); display: flex; }

/* ── Favourites section (above search bar) ───────────────────────────────── */
.ts-favorites {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .3rem .5rem;
    padding-bottom: .5rem;
    border-bottom: 1px solid var(--ts-border-mid);
}
.ts-favorites-label {
    font-size: .72rem;
    color: var(--ts-text-dimmer);
    text-transform: uppercase;
    letter-spacing: .05em;
    flex-shrink: 0;
}
.ts-fav-chip-wrap {
    position: relative;
    display: inline-flex;
    align-items: center;
}
.ts-fav-chip {
    padding: .2rem .55rem;
    font-size: .78rem;
    border-radius: 999px;
    border: 1px solid var(--ts-warn);
    background: var(--ts-bg-raised);
    color: var(--ts-warn);
    cursor: pointer;
    transition: all .15s;
    padding-right: 1.3rem;
}
.ts-fav-chip:hover { background: rgba(250,204,21,.12); }
.ts-fav-chip-star {
    position: absolute;
    right: 4px;
    font-size: .7rem;
    background: none;
    border: none;
    color: var(--ts-warn);
    cursor: pointer;
    padding: 0;
    line-height: 1;
    transition: opacity .15s;
}
.ts-fav-chip-star:hover { opacity: .6; }

/* ── Analysis page ────────────────────────────────────────────────────────── */
.ts-an-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 1rem;
}
.ts-an-card {
    background: var(--ts-bg-raised);
    border: 1px solid var(--ts-border);
    border-radius: 10px;
    overflow: hidden;
}
.ts-an-card-head {
    padding: .75rem 1rem;
    background: var(--ts-bg-card);
    border-bottom: 1px solid var(--ts-border-mid);
}
.ts-an-player-name { font-size: .95rem; font-weight: 700; color: var(--ts-text); margin-bottom: .35rem; }
.ts-an-meta { display: flex; flex-wrap: wrap; gap: .3rem .5rem; align-items: center; }
.ts-an-main-char {
    font-size: .75rem;
    color: var(--ts-accent);
    font-weight: 600;
    background: var(--ts-accent-bg);
    border-radius: 4px;
    padding: .1rem .4rem;
}
.ts-an-stat-chip {
    font-size: .72rem;
    color: var(--ts-text-muted);
    background: var(--ts-bg-chip);
    border-radius: 4px;
    padding: .1rem .4rem;
}
.ts-an-wr       { font-weight: 600; }
.ts-an-wr--pos  { color: var(--ts-success) !important; }
.ts-an-wr--neg  { color: var(--ts-danger) !important; }

.ts-an-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .82rem;
}
.ts-an-table thead tr {
    background: var(--ts-bg-panel);
    border-bottom: 1px solid var(--ts-border-mid);
}
.ts-an-table th {
    padding: .4rem .85rem;
    text-align: left;
    font-size: .7rem;
    font-weight: 600;
    color: var(--ts-text-muted);
    text-transform: uppercase;
    letter-spacing: .05em;
}
.ts-an-table th:not(:first-child) { text-align: right; }
.ts-an-table tbody tr { border-bottom: 1px solid var(--ts-border-sub); }
.ts-an-table tbody tr:last-child { border-bottom: none; }
.ts-an-table tbody tr:hover { background: var(--ts-bg-hover); }
.ts-an-table td { padding: .35rem .85rem; }
.ts-an-char { color: var(--ts-text-card); }
.ts-an-num  { text-align: right; font-variant-numeric: tabular-nums; font-family: 'Consolas', monospace; color: var(--ts-text-muted); }
.ts-an-pos  { color: var(--ts-success) !important; }
.ts-an-neg  { color: var(--ts-danger)  !important; }

/* ── About page ───────────────────────────────────────────────────────────── */
.ts-about { font-size: .9rem; line-height: 1.7; color: var(--ts-text-sub); }
.ts-about h3 { font-size: 1rem; color: var(--ts-text-card); margin: 1.25rem 0 .5rem; }
.ts-about h4 { font-size: .875rem; color: var(--ts-text-card); margin: .9rem 0 .35rem; font-weight: 600; }
.ts-about p { margin: 0 0 .75rem; }
.ts-about ol,
.ts-about ul { margin: 0 0 .75rem 1.5rem; padding: 0; }
.ts-about li { margin-bottom: .3rem; }
.ts-about-kbd {
    display: inline-block;
    font-size: .85em;
    padding: 1px 5px;
    background: var(--ts-bg-chip);
    border: 1px solid var(--ts-border-strong);
    border-radius: 4px;
    color: var(--ts-text);
}
.ts-pwa-picker {
    display: flex;
    align-items: center;
    gap: .6rem;
    margin: .75rem 0;
}
.ts-pwa-picker label {
    font-size: .875rem;
    color: var(--ts-text-muted);
    white-space: nowrap;
}
.ts-pwa-select {
    background: var(--ts-bg-input);
    border: 1px solid var(--ts-border-strong);
    border-radius: 5px;
    color: var(--ts-text-muted);
    font-size: .85rem;
    padding: .25rem .5rem;
    cursor: pointer;
    outline: none;
}
.ts-pwa-select:focus { border-color: var(--ts-accent); color: var(--ts-text); }

/* ── Sidebar expanders (Favorites / Recent) ──────────────────────────────── */
.ts-sb-expander {
    border-bottom: 1px solid var(--ts-border-mid);
    flex-shrink: 0;
}
.ts-sb-expander-header {
    display: flex;
    align-items: center;
    gap: .4rem;
    padding: .4rem 1rem;
    width: 100%;
    background: none;
    border: none;
    color: var(--ts-text-muted);
    font-size: .72rem;
    font-family: inherit;
    text-transform: uppercase;
    letter-spacing: .06em;
    cursor: pointer;
    text-align: left;
    transition: background .15s, color .15s;
}
.ts-sb-expander-header:hover { background: var(--ts-bg-hover); color: var(--ts-text-card); }
.ts-sb-expander-title { flex: 1; }
.ts-sb-expander-count {
    background: var(--ts-bg-chip);
    border-radius: 999px;
    font-size: .65rem;
    font-weight: 700;
    padding: .05rem .3rem;
    color: var(--ts-text-dim);
}
.ts-sb-expander-arrow { font-size: .6rem; color: var(--ts-text-faint); }
.ts-sb-expander-body { padding: .35rem .6rem; display: flex; flex-direction: column; gap: .3rem; }

/* ── Chip rows inside expanders ──────────────────────────────────────────── */
.ts-sb-chip-row { display: flex; align-items: center; gap: .25rem; }
.ts-sb-fav-chip {
    flex: 1;
    padding: .22rem .5rem;
    font-size: .78rem;
    border-radius: 999px;
    border: 1px solid var(--ts-warn);
    background: var(--ts-bg-raised);
    color: var(--ts-warn);
    cursor: pointer;
    text-align: left;
    transition: all .15s;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-family: inherit;
}
.ts-sb-fav-chip:hover { background: rgba(250,204,21,.12); }
.ts-sb-recent-chip-sb {
    flex: 1;
    padding: .22rem .5rem;
    font-size: .78rem;
    border-radius: 999px;
    border: 1px solid var(--ts-border);
    background: var(--ts-bg-raised);
    color: var(--ts-text-muted);
    cursor: pointer;
    text-align: left;
    transition: all .15s;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-family: inherit;
}
.ts-sb-recent-chip-sb:hover { border-color: var(--ts-accent); color: var(--ts-accent); background: var(--ts-accent-bg); }
.ts-sb-chip-star {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    line-height: 1;
    font-size: .8rem;
    color: var(--ts-text-faint);
    flex-shrink: 0;
    transition: color .15s;
}
.ts-sb-chip-star:hover { color: var(--ts-warn); }
.ts-sb-chip-star--on { color: var(--ts-warn); }
.ts-sb-chip-del {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    line-height: 1;
    font-size: .85rem;
    color: var(--ts-text-faint);
    flex-shrink: 0;
    transition: color .15s;
}
.ts-sb-chip-del:hover { color: var(--ts-danger); }

/* ── Section colour picker ───────────────────────────────────────────────── */
.ts-sb-section-color-wrap {
    position: relative;
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
}
.ts-sb-section-palette {
    position: absolute;
    left: 0;
    top: calc(100% + 4px);
    background: var(--ts-bg-panel);
    border: 1px solid var(--ts-border-strong);
    border-radius: 6px;
    padding: 5px;
    display: grid;
    grid-template-columns: repeat(3, 20px);
    gap: 3px;
    z-index: 30;
    box-shadow: 0 4px 12px rgba(0,0,0,.4);
}
.ts-sb-section-color-off {
    grid-column: 1 / -1;
    padding: .15rem .25rem;
    font-size: .68rem;
    background: var(--ts-bg-chip);
    border: 1px solid var(--ts-border-mid);
    border-radius: 3px;
    color: var(--ts-text-muted);
    cursor: pointer;
    text-align: center;
    font-family: inherit;
    transition: all .15s;
    margin-bottom: 1px;
}
.ts-sb-section-color-off:hover { border-color: var(--ts-danger); color: var(--ts-danger); }
.ts-sb-section-color-off--active { background: var(--ts-bg-hover); color: var(--ts-text); border-color: var(--ts-border-strong); }
