@font-face {
    font-family: 'Geist';
    font-style: normal;
    font-weight: 400 700;
    font-display: swap;
    src: url('/vendor/fonts/geist-latin.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
    font-family: 'JetBrains Mono';
    font-style: normal;
    font-weight: 400 600;
    font-display: swap;
    src: url('/vendor/fonts/jetbrains-mono-latin.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root {
    color-scheme: light dark;
    /* Refined Geometric Light Theme */
    --bg-color: #f8f9fa;
    --text-color: #0f1419;
    --text-secondary: #57606a;
    --surface-color: #ffffff;
    --border-color: #d8dce2;
    --node-color: #0ea5e9;
    --link-color: #e5e7eb;
    --label-text-color: #0f1419;
    --label-halo-color: rgba(255, 255, 255, 0.95);
    --node-highlight-color: #0ea5e9;
    --node-highlight-glow: rgba(14, 165, 233, 0.3);
    --node-highlight-core: #ecf8ff;
    --node-highlight-ring: #0ea5e9;
    --merge-node-color: #059669;
    --merge-highlight-color: #059669;
    --merge-highlight-glow: rgba(5, 150, 105, 0.3);
    --merge-highlight-core: #ecfdf5;
    --merge-highlight-ring: #059669;
    --node-shadow-color: rgba(15, 20, 25, 0.08);
    --branch-node-color: #7c3aed;
    --branch-node-border-color: #6d28d9;
    --branch-label-text-color: #ffffff;
    --branch-link-color: #7c3aed;
    --branch-highlight-color: #a78bfa;
    --branch-highlight-glow: rgba(124, 58, 237, 0.3);
    --branch-highlight-core: #f5f3ff;
    --branch-highlight-ring: #a78bfa;
    --tree-node-color: #d97706;
    --tree-node-border-color: #b45309;
    --tree-label-text-color: #ffffff;
    --tree-link-color: #d97706;
    --blob-node-color: #0ea5e9;
    --blob-node-border-color: #0284c7;
    --blob-label-text-color: #ffffff;
    --success-color: #059669;
    --warning-color: #d97706;
    --danger-color: #dc2626;
    --surface-recessed: #f0f1f3;
    --surface-elevated: #ffffff;
    --surface-elevated-shadow: 0 2px 8px rgba(15, 20, 25, 0.12);
    --stash-node-color: #d4a017;
    --stash-node-border-color: #a67c00;
    --index-node-color: #5e8ca0;
    --index-node-border-color: #3d6b80;
    --untracked-node-color: #c47a6c;
    --untracked-node-border-color: #a05a4c;
    --grid-dot-color: rgba(15, 20, 25, 0.06);
    --vignette-opacity: 0.04;

    /* Overlay/settings theming */
    --overlay-bg: rgba(255, 255, 255, 0.82);
    --overlay-border: rgba(0, 0, 0, 0.12);
    --slider-track: #d8dce2;
    --slider-fill: #0ea5e9;
    --slider-thumb: #ffffff;
    --slider-thumb-border: #b0b8c1;
    --minimap-bg: rgba(248, 249, 250, 0.92);
    --minimap-viewport-stroke: #0ea5e9;
    --minimap-viewport-fill: rgba(14, 165, 233, 0.08);
    --breadcrumb-bg: var(--bg-color);
}

@media (prefers-color-scheme: dark) {
    :root {
        /* Refined Geometric Dark Theme */
        --bg-color: #0f1419;
        --text-color: #eaeef2;
        --text-secondary: #8b8f96;
        --surface-color: #161b22;
        --border-color: #30363d;
        --node-color: #58a6ff;
        --link-color: #30363d;
        --label-text-color: #eaeef2;
        --label-halo-color: rgba(22, 27, 34, 0.95);
        --node-highlight-color: #58a6ff;
        --node-highlight-glow: rgba(88, 166, 255, 0.3);
        --node-highlight-core: #0d2342;
        --node-highlight-ring: #58a6ff;
        --merge-node-color: #3fb950;
        --merge-highlight-color: #3fb950;
        --merge-highlight-glow: rgba(63, 185, 80, 0.3);
        --merge-highlight-core: #0d2817;
        --merge-highlight-ring: #3fb950;
        --node-shadow-color: rgba(0, 0, 0, 0.5);
        --branch-node-color: #d8b4fe;
        --branch-node-border-color: #c084fc;
        --branch-label-text-color: #1f1f23;
        --branch-link-color: #d8b4fe;
        --branch-highlight-color: #e9d5ff;
        --branch-highlight-glow: rgba(216, 180, 254, 0.3);
        --branch-highlight-core: #2d1b3d;
        --branch-highlight-ring: #e9d5ff;
        --tree-node-color: #fb923c;
        --tree-node-border-color: #ea580c;
        --tree-label-text-color: #1f1f23;
        --tree-link-color: #fb923c;
        --blob-node-color: #58a6ff;
        --blob-node-border-color: #1f6feb;
        --blob-label-text-color: #161b22;
        --success-color: #3fb950;
        --warning-color: #fb923c;
        --danger-color: #f85149;
        --surface-recessed: #0d1117;
        --surface-elevated: #1c2129;
        --surface-elevated-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
        --stash-node-color: #f0c040;
        --stash-node-border-color: #d4a017;
        --index-node-color: #7aacbf;
        --index-node-border-color: #5a8fa6;
        --untracked-node-color: #dea090;
        --untracked-node-border-color: #c47a6c;
        --grid-dot-color: rgba(234, 238, 242, 0.04);
        --vignette-opacity: 0.15;

        --overlay-bg: rgba(22, 27, 34, 0.82);
        --overlay-border: rgba(255, 255, 255, 0.08);
        --slider-track: #30363d;
        --slider-fill: #58a6ff;
        --slider-thumb: #1c2129;
        --slider-thumb-border: #484f58;
        --minimap-bg: rgba(15, 20, 25, 0.92);
        --minimap-viewport-stroke: #58a6ff;
        --minimap-viewport-fill: rgba(88, 166, 255, 0.08);
        --breadcrumb-bg: var(--bg-color);
    }
}

/* Explicit theme overrides — higher specificity beats the @media query */
:root[data-theme="light"] {
    color-scheme: light;
    --bg-color: #f8f9fa;
    --text-color: #0f1419;
    --text-secondary: #57606a;
    --surface-color: #ffffff;
    --border-color: #d8dce2;
    --node-color: #0ea5e9;
    --link-color: #e5e7eb;
    --label-text-color: #0f1419;
    --label-halo-color: rgba(255, 255, 255, 0.95);
    --node-highlight-color: #0ea5e9;
    --node-highlight-glow: rgba(14, 165, 233, 0.3);
    --node-highlight-core: #ecf8ff;
    --node-highlight-ring: #0ea5e9;
    --merge-node-color: #059669;
    --merge-highlight-color: #059669;
    --merge-highlight-glow: rgba(5, 150, 105, 0.3);
    --merge-highlight-core: #ecfdf5;
    --merge-highlight-ring: #059669;
    --node-shadow-color: rgba(15, 20, 25, 0.08);
    --branch-node-color: #7c3aed;
    --branch-node-border-color: #6d28d9;
    --branch-label-text-color: #ffffff;
    --branch-link-color: #7c3aed;
    --branch-highlight-color: #a78bfa;
    --branch-highlight-glow: rgba(124, 58, 237, 0.3);
    --branch-highlight-core: #f5f3ff;
    --branch-highlight-ring: #a78bfa;
    --tree-node-color: #d97706;
    --tree-node-border-color: #b45309;
    --tree-label-text-color: #ffffff;
    --tree-link-color: #d97706;
    --blob-node-color: #0ea5e9;
    --blob-node-border-color: #0284c7;
    --blob-label-text-color: #ffffff;
    --success-color: #059669;
    --warning-color: #d97706;
    --danger-color: #dc2626;
    --surface-recessed: #f0f1f3;
    --surface-elevated: #ffffff;
    --surface-elevated-shadow: 0 2px 8px rgba(15, 20, 25, 0.12);
    --stash-node-color: #d4a017;
    --stash-node-border-color: #a67c00;
    --index-node-color: #5e8ca0;
    --index-node-border-color: #3d6b80;
    --untracked-node-color: #c47a6c;
    --untracked-node-border-color: #a05a4c;
    --grid-dot-color: rgba(15, 20, 25, 0.06);
    --vignette-opacity: 0.04;
    --overlay-bg: rgba(255, 255, 255, 0.82);
    --overlay-border: rgba(0, 0, 0, 0.12);
    --slider-track: #d8dce2;
    --slider-fill: #0ea5e9;
    --slider-thumb: #ffffff;
    --slider-thumb-border: #b0b8c1;
    --minimap-bg: rgba(248, 249, 250, 0.92);
    --minimap-viewport-stroke: #0ea5e9;
    --minimap-viewport-fill: rgba(14, 165, 233, 0.08);
    --breadcrumb-bg: var(--bg-color);
}

:root[data-theme="dark"] {
    color-scheme: dark;
    --bg-color: #0f1419;
    --text-color: #eaeef2;
    --text-secondary: #8b8f96;
    --surface-color: #161b22;
    --border-color: #30363d;
    --node-color: #58a6ff;
    --link-color: #30363d;
    --label-text-color: #eaeef2;
    --label-halo-color: rgba(22, 27, 34, 0.95);
    --node-highlight-color: #58a6ff;
    --node-highlight-glow: rgba(88, 166, 255, 0.3);
    --node-highlight-core: #0d2342;
    --node-highlight-ring: #58a6ff;
    --merge-node-color: #3fb950;
    --merge-highlight-color: #3fb950;
    --merge-highlight-glow: rgba(63, 185, 80, 0.3);
    --merge-highlight-core: #0d2817;
    --merge-highlight-ring: #3fb950;
    --node-shadow-color: rgba(0, 0, 0, 0.5);
    --branch-node-color: #d8b4fe;
    --branch-node-border-color: #c084fc;
    --branch-label-text-color: #1f1f23;
    --branch-link-color: #d8b4fe;
    --branch-highlight-color: #e9d5ff;
    --branch-highlight-glow: rgba(216, 180, 254, 0.3);
    --branch-highlight-core: #2d1b3d;
    --branch-highlight-ring: #e9d5ff;
    --tree-node-color: #fb923c;
    --tree-node-border-color: #ea580c;
    --tree-label-text-color: #1f1f23;
    --tree-link-color: #fb923c;
    --blob-node-color: #58a6ff;
    --blob-node-border-color: #1f6feb;
    --blob-label-text-color: #161b22;
    --success-color: #3fb950;
    --warning-color: #fb923c;
    --danger-color: #f85149;
    --surface-recessed: #0d1117;
    --surface-elevated: #1c2129;
    --surface-elevated-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
    --stash-node-color: #f0c040;
    --stash-node-border-color: #d4a017;
    --index-node-color: #7aacbf;
    --index-node-border-color: #5a8fa6;
    --untracked-node-color: #dea090;
    --untracked-node-border-color: #c47a6c;
    --grid-dot-color: rgba(234, 238, 242, 0.04);
    --vignette-opacity: 0.15;
    --overlay-bg: rgba(22, 27, 34, 0.82);
    --overlay-border: rgba(255, 255, 255, 0.08);
    --slider-track: #30363d;
    --slider-fill: #58a6ff;
    --slider-thumb: #1c2129;
    --slider-thumb-border: #484f58;
    --minimap-bg: rgba(15, 20, 25, 0.92);
    --minimap-viewport-stroke: #58a6ff;
    --minimap-viewport-fill: rgba(88, 166, 255, 0.08);
    --breadcrumb-bg: var(--bg-color);
}

/* Theme toggle button — positioned to the left of the connection status dot */
.theme-toggle {
    position: fixed;
    bottom: 12px;
    right: 40px;
    z-index: 9999;
    width: 32px;
    height: 32px;
    border-radius: 8px;
    border: 1px solid var(--border-color);
    background: var(--surface-color);
    color: var(--text-color);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    line-height: 1;
    box-shadow: 0 2px 8px var(--node-shadow-color);
    padding: 0;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    font-weight: 500;
}

.theme-toggle:hover {
    border-color: var(--node-color);
    box-shadow: 0 4px 12px rgba(14, 165, 233, 0.2);
    transform: translateY(-2px);
}

.theme-toggle:active {
    transform: translateY(0);
}

.theme-toggle:focus-visible {
    outline: 2px solid var(--node-color);
    outline-offset: 2px;
}

* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    font-family: 'Geist', -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    background: var(--bg-color);
    color: var(--text-color);
    height: 100vh;
    height: 100dvh;
    display: flex;
    padding: 0;
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    letter-spacing: -0.01em;
}

#root {
    flex: 1;
    position: relative;
    background: var(--surface-color);
    border: none;
    border-radius: 0;
    overflow: hidden;
    box-shadow: none;
    position: relative;
    /* Column flex so the filter panel occupies the header row and the canvas
       takes all remaining height via flex: 1 on the canvas element. */
    display: flex;
    flex-direction: column;
}

#root::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 1;
    box-shadow: inset 0 0 120px 40px rgba(0, 0, 0, var(--vignette-opacity));
}

/* ── Activity Bar ── */

.activity-bar {
    width: 48px;
    min-width: 48px;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-top: 8px;
    gap: 4px;
    background: var(--surface-recessed);
    border-right: 1px solid var(--border-color);
    flex-shrink: 0;
    z-index: 10;
}

body.gv-sidebar-dock-right .activity-bar {
    order: 0;
    border-right: 1px solid var(--border-color);
    border-left: none;
}

body.gv-sidebar-dock-right #root {
    order: 1;
}

.activity-bar-icon {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border: none;
    border-radius: 8px;
    background: transparent;
    color: var(--text-secondary);
    cursor: pointer;
    transition: color 0.15s ease, background-color 0.15s ease;
}

.activity-bar-icon::before {
    content: "";
    position: absolute;
    left: -4px;
    top: 8px;
    bottom: 8px;
    width: 3px;
    border-radius: 0 2px 2px 0;
    background: transparent;
    transition: background-color 0.15s ease;
}

.activity-bar-icon:hover {
    color: var(--text-color);
    background: rgba(208, 215, 222, 0.24);
}

@media (prefers-color-scheme: dark) {
    .activity-bar-icon:hover {
        background: rgba(48, 54, 61, 0.6);
    }
}

.activity-bar-icon.is-active {
    color: var(--text-color);
}

.activity-bar-icon.is-active::before {
    background: var(--node-color);
}

.activity-bar-icon:focus-visible {
    outline: 2px solid var(--node-color);
    outline-offset: -2px;
}

.activity-bar-tooltip {
    display: none;
    position: absolute;
    left: calc(100% + 8px);
    top: 50%;
    transform: translateY(-50%);
    padding: 4px 8px;
    border-radius: 4px;
    background: var(--surface-elevated);
    border: 1px solid var(--border-color);
    box-shadow: var(--surface-elevated-shadow);
    font-size: 12px;
    font-weight: 500;
    color: var(--text-color);
    white-space: nowrap;
    pointer-events: none;
    z-index: 100;
}

.activity-bar-icon:hover .activity-bar-tooltip {
    display: block;
}

/* ── Workbench Layout ── */

.workbench {
    display: flex;
    flex: 1;
    min-height: 0;
    min-width: 0;
}

.workbench-dock {
    flex: 1;
    min-width: 0;
    min-height: 0;
}

.dockview-panel-host {
    width: 100%;
    height: 100%;
    min-width: 0;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    overflow-x: hidden;
    container-type: inline-size;
}

.dockview-panel-host > * {
    flex: 1;
    min-height: 0;
    min-width: 0;
}

.workbench-layout {
    flex: 1;
    min-width: 0;
    min-height: 0;
    display: flex;
    flex-direction: row;
    position: relative;
}

.workbench-layout.is-split-horizontal {
    flex-direction: column;
}

.graph-host {
    position: relative;
    display: flex;
    flex-direction: column;
    flex: 1;
    min-width: 0;
    min-height: 0;
}

.workbench-group {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-width: 0;
    min-height: 0;
    border-right: 1px solid var(--border-color);
}

.workbench-group:last-of-type {
    border-right: none;
}

.workbench-group.is-focused .workbench-tabbar {
    box-shadow: inset 0 -1px 0 var(--node-color);
}

.workbench-tabbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 0 8px;
    border-bottom: 1px solid var(--border-color);
    background: color-mix(in srgb, var(--surface-color) 88%, var(--bg-color));
    min-height: 38px;
}

.workbench-tablist {
    position: relative;
    display: flex;
    align-items: center;
    gap: 4px;
    overflow-x: auto;
    scrollbar-width: thin;
}

.workbench-tab-insertion {
    position: absolute;
    top: 5px;
    bottom: 5px;
    width: 2px;
    border-radius: 2px;
    background: var(--node-color);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--surface-color) 72%, transparent);
    transform: translateX(-1px);
    opacity: 0;
    pointer-events: none;
}

.workbench-tab-insertion.is-visible {
    opacity: 1;
}

.workbench-tab {
    border: 1px solid transparent;
    border-bottom: none;
    border-radius: 8px 8px 0 0;
    background: transparent;
    color: var(--text-secondary);
    min-width: 92px;
    max-width: 220px;
    height: 32px;
    padding: 0 8px;
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    cursor: pointer;
    user-select: none;
}

.workbench-tab:hover {
    background: rgba(14, 165, 233, 0.08);
    color: var(--text-color);
}

.workbench-tab.is-active {
    border-color: var(--border-color);
    background: var(--surface-color);
    color: var(--text-color);
}

.workbench-tab.is-dragging {
    opacity: 0.55;
}

.workbench-tab-label {
    font-family: 'Geist', sans-serif;
    font-size: 12px;
    font-weight: 500;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.workbench-tab-close {
    width: 16px;
    height: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 4px;
    font-size: 12px;
    opacity: 0.7;
}

.workbench-tab:hover .workbench-tab-close {
    opacity: 1;
    background: rgba(14, 165, 233, 0.12);
}

.workbench-group-actions {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.workbench-group-btn {
    border: 1px solid var(--border-color);
    background: transparent;
    color: var(--text-secondary);
    border-radius: 7px;
    height: 24px;
    padding: 0 8px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    cursor: pointer;
}

.workbench-group-btn:hover {
    color: var(--text-color);
    border-color: var(--node-color);
    background: rgba(14, 165, 233, 0.08);
}

.workbench-group-content {
    position: relative;
    flex: 1;
    min-height: 0;
    min-width: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    background: var(--surface-color);
}

.workbench-group-content > * {
    flex: 1;
    min-height: 0;
    min-width: 0;
}

.workbench-group.is-drop-target .workbench-tabbar {
    background: color-mix(in srgb, var(--node-color) 14%, var(--surface-color));
}

.workbench-splitter {
    width: 5px;
    height: auto;
    cursor: col-resize;
    background: transparent;
    border-left: 1px solid transparent;
    border-right: 1px solid transparent;
}

.workbench-splitter:hover {
    background: color-mix(in srgb, var(--node-color) 30%, transparent);
}

.workbench-layout.is-split-horizontal .workbench-splitter {
    width: auto;
    height: 5px;
    cursor: row-resize;
    border-left: none;
    border-right: none;
    border-top: 1px solid transparent;
    border-bottom: 1px solid transparent;
}

.workbench-split-overlay {
    position: absolute;
    inset: 0;
    border-radius: 10px;
    background: rgba(7, 12, 19, 0.08);
    display: none;
    align-items: stretch;
    justify-content: stretch;
    z-index: 8;
}

.workbench-split-overlay.is-visible {
    display: block;
}

.workbench-split-preview {
    position: absolute;
    border-radius: 8px;
    border: 1px solid color-mix(in srgb, var(--node-color) 62%, var(--border-color));
    background: color-mix(in srgb, var(--node-color) 14%, transparent);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--node-color) 36%, transparent);
    opacity: 0;
    transition: opacity 90ms ease;
    pointer-events: none;
}

.workbench-split-preview.is-right,
.workbench-split-preview.is-down {
    opacity: 1;
}

.workbench-split-preview.is-right {
    top: 6px;
    right: 6px;
    bottom: 6px;
    width: calc(50% - 9px);
}

.workbench-split-preview.is-down {
    left: 6px;
    right: 6px;
    bottom: 6px;
    height: calc(50% - 9px);
}

.workbench-split-target {
    position: absolute;
    border: 1px dashed color-mix(in srgb, var(--border-color) 76%, transparent);
    border-radius: 8px;
    background: transparent;
    color: color-mix(in srgb, var(--text-secondary) 88%, transparent);
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.02em;
    display: flex;
    align-items: flex-start;
    justify-content: flex-end;
    padding: 6px 8px;
    text-transform: uppercase;
    pointer-events: auto;
}

.workbench-split-target--right {
    top: 6px;
    right: 6px;
    bottom: 6px;
    width: calc(50% - 9px);
}

.workbench-split-target--down {
    left: 6px;
    right: 6px;
    bottom: 6px;
    height: calc(50% - 9px);
}

.workbench-split-target.is-target {
    border-color: var(--node-color);
    color: var(--node-color);
    background: color-mix(in srgb, var(--node-color) 8%, transparent);
}

.workbench-secondary-hint {
    position: absolute;
    inset: 48px 16px 16px auto;
    width: 280px;
    border: 1px dashed var(--border-color);
    border-radius: 10px;
    color: var(--text-secondary);
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    display: none;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 16px;
    pointer-events: auto;
}

.workbench-secondary-hint.is-active {
    border-color: var(--node-color);
    color: var(--node-color);
    background: rgba(14, 165, 233, 0.06);
}

@media (max-width: 860px) {
    .workbench {
        flex-direction: column;
    }

    .activity-bar {
        width: 100%;
        min-width: 100%;
        height: 48px;
        flex-direction: row;
        justify-content: flex-start;
        padding: 0 8px;
        border-right: none;
        border-bottom: 1px solid var(--border-color);
        overflow-x: auto;
    }

    .activity-bar-icon::before {
        left: 8px;
        right: 8px;
        top: auto;
        bottom: -2px;
        width: auto;
        height: 2px;
        border-radius: 2px 2px 0 0;
    }

    .activity-bar-tooltip {
        display: none !important;
    }

    .workbench-layout {
        flex-direction: column;
    }

    .workbench-group {
        border-right: none;
        border-bottom: 1px solid var(--border-color);
    }

    .workbench-splitter {
        display: none !important;
    }

    .workbench-secondary-hint {
        position: static;
        width: auto;
        margin: 12px;
    }
}

/* ── Sidebar Panel ── */

.sidebar-panel {
    position: relative;
    display: flex;
    flex-direction: column;
    background: var(--surface-color);
    border-right: 1px solid var(--border-color);
    overflow: hidden;
    width: 0;
    min-width: 0;
    z-index: 16;
}

body.gv-sidebar-dock-right .sidebar-panel {
    order: 2;
    border-right: none;
    border-left: 1px solid var(--border-color);
}

.sidebar-panel.is-resizing {
    transition: none;
}

body.gv-sidebar-dock-left .sidebar-panel:not(.is-open),
body.gv-sidebar-dock-right .sidebar-panel:not(.is-open) {
    border-right: none;
}

body.gv-sidebar-dock-right .sidebar-panel:not(.is-open) {
    border-left: none;
}

.sidebar-panel:not(.is-open) .sidebar-panel-header,
.sidebar-panel:not(.is-open) .sidebar-panel-content,
.sidebar-panel:not(.is-open) .sidebar-panel-handle {
    display: none;
}

.sidebar-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 12px;
    border-bottom: 1px solid var(--border-color);
    flex-shrink: 0;
    background: linear-gradient(135deg, var(--surface-color) 0%, rgba(14, 165, 233, 0.02) 100%);
}

.sidebar-panel-title {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-secondary);
}

.sidebar-panel-controls {
    display: flex;
    align-items: center;
    gap: 8px;
}

.sidebar-dock-switch {
    display: inline-flex;
    align-items: center;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    overflow: hidden;
    background: var(--surface-color);
}

.sidebar-dock-btn {
    border: none;
    border-right: 1px solid var(--border-color);
    width: 24px;
    height: 24px;
    background: transparent;
    color: var(--text-secondary);
    font-size: 11px;
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-weight: 600;
    cursor: pointer;
    transition: background-color 0.12s ease, color 0.12s ease;
}

.sidebar-dock-btn:last-child {
    border-right: none;
}

.sidebar-dock-btn:hover {
    color: var(--text-color);
    background: rgba(14, 165, 233, 0.1);
}

.sidebar-dock-btn.is-active {
    color: #fff;
    background: var(--node-color);
}

.sidebar-panel-close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    border: none;
    border-radius: 6px;
    background: transparent;
    color: var(--text-secondary);
    cursor: pointer;
    transition: background-color 0.15s ease, color 0.15s ease;
}

.sidebar-panel-close:hover {
    background: rgba(208, 215, 222, 0.32);
    color: var(--text-color);
}

@media (prefers-color-scheme: dark) {
    .sidebar-panel-close:hover {
        background: rgba(48, 54, 61, 0.8);
    }
}

.sidebar-panel-content {
    flex: 1;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.sidebar-panel-tab-content {
    display: none;
    flex: 1;
    overflow: hidden;
    flex-direction: column;
}

.sidebar-panel-tab-content.is-active {
    display: flex;
}

.sidebar-panel-handle {
    position: absolute;
    top: 0;
    right: 0;
    width: 4px;
    height: 100%;
    cursor: col-resize;
    z-index: 20;
}

body.gv-sidebar-dock-right .sidebar-panel-handle {
    right: auto;
    left: 0;
}

.sidebar-panel-handle:hover,
.sidebar-panel.is-resizing .sidebar-panel-handle {
    background: var(--node-color);
    opacity: 0.5;
}

/* Fullscreen dock mode */
.sidebar-fullscreen-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(6, 12, 20, 0.28);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    z-index: 24;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.14s ease;
}

.sidebar-fullscreen-backdrop.is-visible {
    opacity: 1;
    pointer-events: auto;
}

body.gv-sidebar-dock-fullscreen .sidebar-panel {
    position: fixed;
    left: 48px;
    right: 0;
    top: 0;
    bottom: 0;
    width: auto !important;
    border-left: 1px solid var(--border-color);
    border-right: none;
    z-index: 30;
    box-shadow: -20px 0 40px rgba(0, 0, 0, 0.18);
}

body.gv-sidebar-dock-fullscreen .sidebar-panel:not(.is-open) {
    display: none;
}

body.gv-sidebar-dock-fullscreen .sidebar-panel-handle {
    display: none;
}

body.gv-sidebar-dock-fullscreen .sidebar-panel-header {
    padding: 12px 14px;
}

body.gv-sidebar-dock-fullscreen .sidebar-panel-title {
    font-size: 13px;
}

/* Drag to dock overlay */
.sidebar-drag-overlay {
    position: fixed;
    inset: 0;
    z-index: 60;
    display: none;
    align-items: center;
    justify-content: center;
    background: rgba(7, 12, 19, 0.2);
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);
}

.sidebar-drag-overlay.is-visible {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.sidebar-drag-overlay-title {
    font-family: 'Geist', sans-serif;
    font-size: 14px;
    font-weight: 600;
    color: #fff;
    letter-spacing: 0.01em;
}

.sidebar-drop-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(130px, 1fr));
    gap: 10px;
    width: min(560px, calc(100vw - 40px));
}

.sidebar-drop-zone {
    appearance: none;
    border: 1px solid rgba(255, 255, 255, 0.35);
    border-radius: 12px;
    background: rgba(10, 17, 27, 0.48);
    color: #e6edf3;
    padding: 14px 12px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
    text-align: left;
    transition: transform 0.12s ease, border-color 0.12s ease, background-color 0.12s ease;
}

.sidebar-drop-zone-key {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.12);
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    font-weight: 700;
}

.sidebar-drop-zone-label {
    font-family: 'Geist', sans-serif;
    font-size: 13px;
    font-weight: 600;
}

.sidebar-drop-zone.is-target {
    transform: translateY(-2px) scale(1.02);
    border-color: var(--node-color);
    background: color-mix(in srgb, var(--node-color) 28%, rgba(10, 17, 27, 0.55));
}

@media (max-width: 900px) {
    .sidebar-drop-grid {
        grid-template-columns: 1fr;
        width: min(360px, calc(100vw - 28px));
    }

    body.gv-sidebar-dock-fullscreen .sidebar-panel {
        left: 0;
    }
}

/* ── Info Bar ── */

.info-bar {
    border-bottom: 1px solid var(--border-color);
    flex-shrink: 0;
}

.info-bar-header {
    display: flex;
    align-items: center;
    gap: 6px;
    width: 100%;
    padding: 8px 12px;
    border: none;
    background: transparent;
    color: var(--text-color);
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    text-align: left;
    transition: background-color 0.15s ease;
}

.info-bar-header:hover {
    background: rgba(208, 215, 222, 0.24);
}

@media (prefers-color-scheme: dark) {
    .info-bar-header:hover {
        background: rgba(48, 54, 61, 0.5);
    }
}

.info-bar-chevron {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.15s ease;
    transform: rotate(90deg);
    color: var(--text-secondary);
}

.info-bar.is-collapsed .info-bar-chevron {
    transform: rotate(0deg);
}

.info-bar-title {
    flex: 1;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-secondary);
    font-size: 11px;
    font-weight: 600;
}

.info-bar-content {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 0 12px 8px;
}

.info-bar.is-collapsed .info-bar-content {
    display: none;
}

.info-bar-row {
    display: flex;
    align-items: baseline;
    gap: 8px;
    padding: 3px 4px;
    border-radius: 4px;
    font-size: 11px;
    transition: background-color 0.1s ease;
}

.info-bar-row:hover {
    background: rgba(208, 215, 222, 0.16);
}

@media (prefers-color-scheme: dark) {
    .info-bar-row:hover {
        background: rgba(48, 54, 61, 0.4);
    }
}

.info-bar-label {
    font-weight: 600;
    color: var(--text-secondary);
    flex-shrink: 0;
    min-width: 80px;
}

.info-bar-value {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    color: var(--text-color);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
}

.info-bar-value--detached {
    color: var(--warning-color);
    font-weight: 600;
}

.info-bar-value--remote-url {
    font-size: 11px;
    color: var(--text-secondary);
}

/* ── File Explorer ── */

.file-explorer {
    display: flex;
    flex-direction: column;
    height: 100%;
    overflow: hidden;
}

.file-explorer-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 8px 12px;
    border-bottom: 1px solid var(--border-color);
    flex-shrink: 0;
}

.file-explorer-commit {
    font-family: ui-monospace, SFMono-Regular, SFMono, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 11px;
    color: rgba(99, 110, 123, 0.8);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    flex: 1;
    min-width: 0;
}

.file-explorer-toggle {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 5px 10px;
    font-size: 11px;
    font-weight: 500;
    color: var(--text-secondary);
    background: transparent;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.15s ease;
    flex-shrink: 0;
    white-space: nowrap;
}

.file-explorer-toggle:hover {
    background: rgba(14, 165, 233, 0.08);
    border-color: var(--node-color);
    color: var(--node-color);
}

.file-explorer-toggle:active {
    background: rgba(14, 165, 233, 0.12);
}

@media (prefers-color-scheme: dark) {
    .file-explorer-toggle:hover {
        background: rgba(48, 54, 61, 0.5);
    }
    .file-explorer-toggle:active {
        background: rgba(48, 54, 61, 0.7);
    }
}

.file-explorer-placeholder {
    padding: 24px 16px;
    text-align: center;
    font-size: 13px;
    color: rgba(99, 110, 123, 0.6);
}

.file-explorer-tree {
    flex: 1;
    overflow-y: auto;
    padding: 4px 0;
}

.file-explorer-tree:focus {
    outline: none;
}

.file-explorer-tree:focus .explorer-entry.is-focused {
    outline: 2px solid var(--node-color);
    outline-offset: -2px;
}

.explorer-entry.is-focused {
    background: rgba(208, 215, 222, 0.16);
}

@media (prefers-color-scheme: dark) {
    .explorer-entry.is-focused {
        background: rgba(48, 54, 61, 0.4);
    }
}

.explorer-entry {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 8px;
    font-size: 12px;
    cursor: pointer;
    border-radius: 6px;
    margin: 0 4px;
    transition: all 0.12s ease;
}

.explorer-entry:hover {
    background: rgba(14, 165, 233, 0.08);
}

.explorer-entry.is-selected {
    background: rgba(14, 165, 233, 0.12);
    color: var(--node-color);
}

.explorer-chevron {
    display: inline-flex;
    width: 16px;
    height: 16px;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: transform 0.12s ease;
    transform: rotate(0deg);
    color: rgba(99, 110, 123, 0.7);
}

.explorer-chevron.is-expanded {
    transform: rotate(90deg);
}

.explorer-chevron-spacer {
    width: 16px;
    flex-shrink: 0;
}

.explorer-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 16px;
    height: 16px;
    color: var(--text-color);
}

.explorer-name {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}

.explorer-blame {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
    font-size: 11px;
    color: rgba(99, 110, 123, 0.7);
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}

.explorer-blame-age {
    width: 48px;
    text-align: right;
}

.explorer-blame-hash {
    width: 52px;
}

/* ── Canvas Toolbar ── */

/*
 * In-flow strip between the filter panel and the canvas. Contains
 * commit search and graph layout controls.
 */
.canvas-toolbar {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 3px 8px;
    background: var(--bg-color);
    border-bottom: 1px solid var(--border-color);
    flex-shrink: 0;
    font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, monospace;
    font-size: 11px;
}

canvas {
    /* flex: 1 so the canvas fills all space not consumed by the toolbar.
       min-height: 0 prevents flex children from overflowing the container. */
    flex: 1;
    width: 100%;
    min-height: 0;
    display: block;
    background: var(--surface-color);
    touch-action: none;
}

/* ── Search Bar ── */

.search-container {
    flex: 1;
    min-width: 0;
    max-width: 300px;
    /* Transition is defined here so the width animates in both directions
       (expanding on focus, contracting on blur). */
    transition: max-width 0.2s ease;
}

/*
 * Outer wrapper providing the relative positioning context for the dropdown.
 * It spans 100% of .search-container and does not clip overflow, so the
 * dropdown can appear below the toolbar strip.
 */
.commit-search-positioner {
    position: relative;
    width: 100%;
}

.commit-search {
    display: flex;
    align-items: center;
    background: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    /* overflow:hidden removed — the dropdown positions outside the wrapper */
    transition: border-color 0.15s ease, box-shadow 0.15s ease, max-width 0.2s ease;
    width: 100%;
    position: relative; /* needed for absolute-positioned icon and clear button */
}

.commit-search:focus-within,
.commit-search.is-focused {
    border-color: var(--node-color);
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.15);
}

@media (prefers-color-scheme: dark) {
    .commit-search:focus-within,
    .commit-search.is-focused {
        box-shadow: 0 0 0 3px rgba(88, 166, 255, 0.18);
    }
}

/* Magnifier icon — positioned to the left of the input text. */
.commit-search-icon {
    position: absolute;
    left: 10px;
    display: inline-flex;
    align-items: center;
    color: var(--text-secondary);
    pointer-events: none;
    opacity: 0.7;
}

.commit-search-input {
    flex: 1;
    min-width: 0;
    /* Left padding makes room for the absolutely-positioned magnifier icon.
       Right padding is kept small since the result count and clear button
       are flex siblings that follow the input in the row. */
    padding: 8px 4px 8px 30px;
    border: none;
    background: transparent;
    font-size: 13px;
    font-family: inherit;
    color: var(--text-color);
    outline: none;
    /* Remove browser-native search decorations (Webkit cancel button, IE clear).
       Our custom clear button replaces them for cross-browser consistency. */
    -webkit-appearance: none;
    appearance: none;
}

.commit-search-input::-webkit-search-cancel-button,
.commit-search-input::-webkit-search-decoration {
    -webkit-appearance: none;
    appearance: none;
}

.commit-search-input::placeholder {
    color: var(--text-secondary);
    opacity: 0.6;
}

/*
 * Result count badge — shown inline between the input and clear button when a
 * search is active.  Uses monospace so digit widths stay stable as count changes.
 */
.commit-search-result-count {
    display: none;
    align-items: center;
    flex-shrink: 0;
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 11px;
    font-weight: 500;
    color: var(--text-secondary);
    white-space: nowrap;
    padding: 0 6px 0 4px;
    pointer-events: none;
}

/* Zero-results warning: highlight in warning color */
.commit-search-result-count.is-empty {
    color: var(--warning-color);
}

/* Clear (×) button — hidden until the input has content. */
.commit-search-clear {
    display: none; /* toggled via JS */
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    margin-right: 5px;
    border: none;
    border-radius: 4px;
    background: transparent;
    color: var(--text-secondary);
    font-size: 16px;
    line-height: 1;
    cursor: pointer;
    padding: 0;
    transition: color 0.12s ease, background 0.12s ease;
}

.commit-search-clear:hover {
    color: var(--text-color);
    background: rgba(14, 165, 233, 0.08);
}

@media (prefers-color-scheme: dark) {
    .commit-search-clear:hover {
        background: rgba(88, 166, 255, 0.1);
    }
}

.commit-search-clear:focus-visible {
    box-shadow: 0 0 0 2px var(--node-color);
    border-radius: 4px;
    outline: none;
}

/* ── Search Expand on Focus ── */

/*
 * When the search container (and hence positioner) gains focus-within, the
 * parent .search-container's max-width expands from 300px to 480px.
 * We do this on the container rather than the wrapper so the positioner
 * naturally widens with it.
 */
.search-container:focus-within {
    max-width: 480px;
    transition: max-width 0.2s ease;
}

/* ── Search Dropdown ── */

/*
 * The dropdown is position:absolute relative to .commit-search-positioner,
 * dropping below the search bar.  z-index matches the filter popover (50).
 */
.commit-search-dropdown {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    z-index: 50;
    background: var(--surface-elevated);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    box-shadow: var(--surface-elevated-shadow);
    overflow: hidden;
    /* Constrain height so the dropdown doesn't cover the entire canvas */
    max-height: 320px;
    overflow-y: auto;
}

/* Section header within the dropdown */
.commit-search-dropdown-section {
    padding: 4px 0;
}

.commit-search-dropdown-section + .commit-search-dropdown-section {
    border-top: 1px solid var(--border-color);
}

.commit-search-dropdown-heading {
    padding: 6px 12px 4px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-secondary);
    user-select: none;
}

/* ── Qualifier Suggestion Row ── */

.commit-search-suggestion {
    display: flex;
    align-items: baseline;
    gap: 10px;
    padding: 7px 12px;
    cursor: pointer;
    transition: background-color 0.1s ease;
}

.commit-search-suggestion:hover,
.commit-search-suggestion:focus {
    background: rgba(14, 165, 233, 0.07);
    outline: none;
}

@media (prefers-color-scheme: dark) {
    .commit-search-suggestion:hover,
    .commit-search-suggestion:focus {
        background: rgba(88, 166, 255, 0.09);
    }
}

.commit-search-suggestion-keyword {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 12px;
    font-weight: 600;
    color: var(--node-color);
    white-space: nowrap;
    flex-shrink: 0;
    min-width: 110px;
}

.commit-search-suggestion-desc {
    font-size: 12px;
    color: var(--text-secondary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ── Recent Search Row ── */

.commit-search-recent {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 7px 12px;
    cursor: pointer;
    transition: background-color 0.1s ease;
}

.commit-search-recent:hover,
.commit-search-recent:focus {
    background: rgba(14, 165, 233, 0.07);
    outline: none;
}

@media (prefers-color-scheme: dark) {
    .commit-search-recent:hover,
    .commit-search-recent:focus {
        background: rgba(88, 166, 255, 0.09);
    }
}

.commit-search-recent-icon {
    display: inline-flex;
    align-items: center;
    color: var(--text-secondary);
    opacity: 0.7;
    flex-shrink: 0;
}

.commit-search-recent-text {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 12px;
    color: var(--text-color);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ── Keyboard navigation active state ── */

.commit-search-suggestion.is-active,
.commit-search-recent.is-active {
    background: rgba(14, 165, 233, 0.12);
    outline: 2px solid var(--node-color);
    outline-offset: -2px;
}

@media (prefers-color-scheme: dark) {
    .commit-search-suggestion.is-active,
    .commit-search-recent.is-active {
        background: rgba(88, 166, 255, 0.14);
    }
}

/* ── Parse-error hint ── */

.commit-search-parse-hint {
    padding: 6px 12px;
    font-size: 12px;
    color: var(--warning-color, #b45309);
    background: var(--surface-color);
    border: 1px solid var(--warning-color, #b45309);
    border-radius: 6px;
    margin-top: 4px;
    line-height: 1.4;
}

@media (prefers-color-scheme: dark) {
    .commit-search-parse-hint {
        color: #fbbf24;
        border-color: #fbbf24;
    }
}

/* ── Scope indicator footer ── */

.commit-search-dropdown-footer {
    padding: 6px 12px;
    font-size: 11px;
    color: var(--text-secondary);
    opacity: 0.7;
    border-top: 1px solid var(--border-color);
    text-align: center;
    user-select: none;
}

.graph-controls {
    display: flex;
    gap: 0;
    padding: 0;
    border-radius: 10px;
    background: var(--surface-color);
    border: 1px solid var(--border-color);
    overflow: hidden;
    flex-shrink: 0;
    margin-left: auto;
}

.graph-controls button {
    border: none;
    border-right: 1px solid var(--border-color);
    border-radius: 0;
    padding: 3px 8px;
    font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, monospace;
    font-size: 11px;
    font-weight: 500;
    background: transparent;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.15s ease;
    position: relative;
}

.graph-controls button:first-child {
    border-top-left-radius: 10px;
    border-bottom-left-radius: 10px;
}

.graph-controls button:last-child {
    border-top-right-radius: 10px;
    border-bottom-right-radius: 10px;
    border-right: none;
}

.graph-controls button:hover {
    background: rgba(14, 165, 233, 0.08);
    color: var(--text-color);
}

@media (prefers-color-scheme: dark) {
    .graph-controls button:hover {
        background: rgba(88, 166, 255, 0.1);
    }
}

.graph-controls button.is-active {
    background: var(--node-color);
    color: #ffffff;
    font-weight: 600;
}

.graph-controls button.is-active:hover {
    background: var(--node-color);
    opacity: 0.95;
}

.graph-controls button:focus-visible {
    outline: 2px solid var(--node-color);
    outline-offset: -2px;
    z-index: 1;
    position: relative;
}

.graph-controls button:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.graph-controls button:disabled:hover {
    background: var(--surface-color);
}

.commit-tooltip {
    position: fixed;
    pointer-events: none;
    background: var(--surface-elevated);
    color: var(--text-color);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    box-shadow: var(--surface-elevated-shadow);
    padding: 14px 16px;
    max-width: min(380px, 70vw);
    display: none;
    flex-direction: column;
    gap: 10px;
    z-index: 15;
    opacity: 0;
    transition: opacity 0.15s cubic-bezier(0.4, 0, 0.2, 1);
    backdrop-filter: blur(8px);
}

/* Navigation row appended to the commit tooltip.
   Re-enables pointer-events on just this element so the Prev/Next buttons
   are clickable even though the parent tooltip is pointer-events: none. */
.commit-tooltip-nav {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    padding-top: 6px;
    border-top: 1px solid var(--border-color);
    pointer-events: auto;
}

.commit-tooltip-nav-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 5px 10px;
    font-size: 11px;
    font-weight: 500;
    color: var(--text-secondary);
    background: transparent;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.15s ease;
    font-family: inherit;
}

.commit-tooltip-nav-btn:hover {
    background: rgba(14, 165, 233, 0.08);
    color: var(--node-color);
    border-color: var(--node-color);
}

@media (prefers-color-scheme: dark) {
    .commit-tooltip-nav-btn:hover {
        background: rgba(48, 54, 61, 0.8);
    }
}

.commit-tooltip-nav-btn:disabled {
    opacity: 0.35;
    cursor: default;
}

@media (prefers-color-scheme: dark) {
    .commit-tooltip {
        box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5);
    }
}

.commit-tooltip:not([hidden]) {
    opacity: 1;
}

.commit-tooltip-header {
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: 12px;
    line-height: 1.4;
    color: var(--text-color);
}

.commit-tooltip-hash {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 11px;
    font-weight: 600;
    background: rgba(14, 165, 233, 0.12);
    border-radius: 6px;
    padding: 6px 8px;
    width: max-content;
    color: var(--node-color);
    letter-spacing: 0.5px;
}

@media (prefers-color-scheme: dark) {
    .commit-tooltip-hash {
        background: rgba(88, 166, 255, 0.15);
    }
}

@media (prefers-color-scheme: dark) {
    .commit-tooltip {
        box-shadow: 0 12px 32px rgba(0, 0, 0, 0.5);
    }
}

.commit-tooltip-meta {
    white-space: pre-wrap;
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    color: var(--text-secondary);
}

.commit-tooltip-message {
    margin: 0;
    white-space: pre-wrap;
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 12px;
    line-height: 1.5;
    color: var(--text-color);
}

/* ── Branch tooltip ── */

.branch-tooltip {
    position: fixed;
    pointer-events: none;
    background: var(--surface-elevated);
    color: var(--text-color);
    border: 1px solid var(--border-color);
    border-left: 3px solid var(--branch-node-color);
    border-radius: 10px;
    box-shadow: var(--surface-elevated-shadow);
    padding: 12px 14px;
    min-width: 160px;
    display: none;
    flex-direction: column;
    gap: 8px;
    z-index: 15;
    opacity: 0;
    transition: opacity 0.15s cubic-bezier(0.4, 0, 0.2, 1);
    backdrop-filter: blur(8px);
}

.branch-tooltip:not([hidden]) {
    opacity: 1;
}

.branch-tooltip-name-row {
    display: flex;
    align-items: center;
    gap: 6px;
}

.branch-tooltip-name {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.01em;
    padding: 4px 8px;
    border-radius: 6px;
    background: rgba(130, 80, 223, 0.1);
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

@media (prefers-color-scheme: dark) {
    .branch-tooltip-name {
        background: rgba(188, 140, 255, 0.12);
    }
}

.branch-tooltip-name::before {
    content: "";
    width: 8px;
    height: 8px;
    flex-shrink: 0;
    border-radius: 50%;
    background: var(--branch-node-color);
    box-shadow: 0 0 0 2px rgba(130, 80, 223, 0.2);
}

@media (prefers-color-scheme: dark) {
    .branch-tooltip-name::before {
        box-shadow: 0 0 0 2px rgba(188, 140, 255, 0.2);
    }
}

.branch-tooltip-copy {
    background: none;
    border: none;
    cursor: pointer;
    padding: 2px;
    color: var(--text-secondary, #656d76);
    display: flex;
    align-items: center;
    pointer-events: auto;
    border-radius: 4px;
    flex-shrink: 0;
    transition: color 0.15s ease;
}

.branch-tooltip-copy:hover {
    color: var(--branch-node-color);
}

.branch-tooltip-badge {
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 1px 6px;
    border-radius: 4px;
    width: max-content;
}

.branch-tooltip-badge--local {
    color: #1a7f37;
    background: rgba(26, 127, 55, 0.1);
}

.branch-tooltip-badge--remote {
    color: #9a6700;
    background: rgba(154, 103, 0, 0.1);
}

@media (prefers-color-scheme: dark) {
    .branch-tooltip-badge--local {
        color: #56d364;
        background: rgba(86, 211, 100, 0.12);
    }
    .branch-tooltip-badge--remote {
        color: #d29922;
        background: rgba(210, 153, 34, 0.12);
    }
}

.branch-tooltip-target {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.04em;
    color: var(--branch-node-color);
    background: rgba(130, 80, 223, 0.08);
    border-radius: 6px;
    padding: 4px 8px;
    width: max-content;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

@media (prefers-color-scheme: dark) {
    .branch-tooltip-target {
        background: rgba(188, 140, 255, 0.1);
    }
}

.branch-tooltip-target::before {
    content: "→";
    font-size: 12px;
}

/* ── Tag tooltip ── */

.tag-tooltip {
    position: fixed;
    pointer-events: none;
    background: var(--surface-elevated);
    color: var(--text-color);
    border: 1px solid var(--border-color);
    border-left: 3px solid #9a6700;
    border-radius: 10px;
    box-shadow: var(--surface-elevated-shadow);
    padding: 12px 14px;
    min-width: 160px;
    display: none;
    flex-direction: column;
    gap: 8px;
    z-index: 15;
    opacity: 0;
    transition: opacity 0.15s cubic-bezier(0.4, 0, 0.2, 1);
    backdrop-filter: blur(8px);
}

@media (prefers-color-scheme: dark) {
    .tag-tooltip {
        border-left-color: #d29922;
    }
}

.tag-tooltip:not([hidden]) {
    opacity: 1;
}

.tag-tooltip-name-row {
    display: flex;
    align-items: center;
    gap: 6px;
}

.tag-tooltip-name {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.01em;
    padding: 4px 8px;
    border-radius: 6px;
    background: rgba(154, 103, 0, 0.1);
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

@media (prefers-color-scheme: dark) {
    .tag-tooltip-name {
        background: rgba(210, 153, 34, 0.12);
    }
}

.tag-tooltip-name::before {
    content: "⌂";
    font-size: 11px;
    flex-shrink: 0;
    color: #9a6700;
}

@media (prefers-color-scheme: dark) {
    .tag-tooltip-name::before {
        color: #d29922;
    }
}

.tag-tooltip-copy {
    background: none;
    border: none;
    cursor: pointer;
    padding: 2px;
    color: var(--text-secondary, #656d76);
    display: flex;
    align-items: center;
    pointer-events: auto;
    border-radius: 4px;
    flex-shrink: 0;
    transition: color 0.15s ease;
}

.tag-tooltip-copy:hover {
    color: #9a6700;
}

@media (prefers-color-scheme: dark) {
    .tag-tooltip-copy:hover {
        color: #d29922;
    }
}

.tag-tooltip-target {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.04em;
    color: #9a6700;
    background: rgba(154, 103, 0, 0.08);
    border-radius: 6px;
    padding: 4px 8px;
    width: max-content;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

@media (prefers-color-scheme: dark) {
    .tag-tooltip-target {
        color: #d29922;
        background: rgba(210, 153, 34, 0.1);
    }
}

.tag-tooltip-target::before {
    content: "→";
    font-size: 12px;
}

.blob-tooltip {
    position: fixed;
    pointer-events: none;
    background: var(--surface-elevated);
    color: var(--text-color);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    box-shadow: var(--surface-elevated-shadow);
    padding: 12px 14px;
    min-width: 160px;
    display: none;
    flex-direction: column;
    gap: 8px;
    z-index: 15;
    opacity: 0;
    transition: opacity 0.15s cubic-bezier(0.4, 0, 0.2, 1);
    backdrop-filter: blur(8px);
}

.blob-tooltip:not([hidden]) {
    opacity: 1;
}

.blob-tooltip-name {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.01em;
    padding: 4px 8px;
    border-radius: 6px;
    background: rgba(208, 215, 222, 0.48);
}

@media (prefers-color-scheme: dark) {
    .blob-tooltip-name {
        background: rgba(48, 54, 61, 0.8);
    }
}

.blob-tooltip-name::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--blob-node-color, #0969da);
    box-shadow: 0 0 0 2px rgba(9, 105, 218, 0.2);
}

@media (prefers-color-scheme: dark) {
    .blob-tooltip-name::before {
        background: var(--blob-node-color, #58a6ff);
        box-shadow: 0 0 0 2px rgba(88, 166, 255, 0.2);
    }
}

.blob-tooltip-hash {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 12px;
    letter-spacing: 0.04em;
    color: var(--text-secondary);
}

.blob-tooltip-mode {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 11px;
    color: var(--text-secondary);
}

/* ── Index View ── */

.index-view {
    display: grid;
    gap: 12px;
    padding: 12px;
    align-content: start;
    overflow-y: auto;
    background:
        radial-gradient(circle at 92% 12%, color-mix(in srgb, var(--node-color) 16%, transparent) 0%, transparent 38%),
        linear-gradient(170deg, color-mix(in srgb, var(--surface-color) 84%, var(--bg-color)) 0%, var(--surface-color) 100%);
}

.repo-overview-hero {
    border: 1px solid color-mix(in srgb, var(--border-color) 88%, transparent);
    border-radius: 14px;
    padding: 14px 14px 12px;
    background:
        linear-gradient(145deg, color-mix(in srgb, var(--surface-color) 72%, transparent), color-mix(in srgb, var(--surface-color) 96%, var(--bg-color))),
        repeating-linear-gradient(-36deg, color-mix(in srgb, var(--border-color) 16%, transparent) 0 6px, transparent 6px 16px);
    box-shadow: 0 12px 32px color-mix(in srgb, var(--node-color) 12%, transparent);
}

.repo-overview-eyebrow {
    font-size: 11px;
    letter-spacing: 0.14em;
    font-weight: 600;
    text-transform: uppercase;
    margin-bottom: 8px;
    color: var(--text-secondary);
}

.repo-overview-title {
    margin: 0;
    font-size: 19px;
    line-height: 1.15;
    font-weight: 650;
    font-family: 'Geist', sans-serif;
    color: var(--text-color);
    word-break: break-word;
}

.repo-overview-subtitle {
    margin: 6px 0 0;
    font-size: 12px;
    color: var(--text-secondary);
}

.repo-overview-pills {
    margin-top: 11px;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.repo-pill {
    display: inline-flex;
    align-items: center;
    max-width: 100%;
    min-height: 23px;
    border-radius: 999px;
    padding: 0 10px;
    font-size: 11px;
    line-height: 1;
    letter-spacing: 0.02em;
    border: 1px solid color-mix(in srgb, var(--border-color) 80%, transparent);
    background: color-mix(in srgb, var(--surface-color) 90%, transparent);
    color: var(--text-secondary);
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.repo-pill--branch {
    color: var(--node-color);
    border-color: color-mix(in srgb, var(--node-color) 40%, var(--border-color));
    background: color-mix(in srgb, var(--node-color) 14%, transparent);
}

.repo-pill--head {
    color: var(--success-color);
    border-color: color-mix(in srgb, var(--success-color) 34%, var(--border-color));
    background: color-mix(in srgb, var(--success-color) 12%, transparent);
}

.repo-pill--warning {
    color: var(--warning-color);
    border-color: color-mix(in srgb, var(--warning-color) 42%, var(--border-color));
    background: color-mix(in srgb, var(--warning-color) 14%, transparent);
}

.repo-metric-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.repo-metric-card {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 5px;
    padding: 11px 10px;
    border-radius: 10px;
    border: 1px solid color-mix(in srgb, var(--border-color) 88%, transparent);
    background: color-mix(in srgb, var(--surface-color) 94%, var(--bg-color));
    overflow: hidden;
}

.repo-metric-card::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 2px;
    background: linear-gradient(90deg, color-mix(in srgb, var(--node-color) 75%, transparent), transparent);
    opacity: 0.8;
}

.repo-metric-label {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.repo-metric-value {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 18px;
    line-height: 1;
    font-weight: 600;
    color: var(--text-color);
}

.repo-details-grid {
    display: grid;
    gap: 8px;
    grid-template-columns: 1fr;
}

.repo-detail-card {
    border: 1px solid color-mix(in srgb, var(--border-color) 88%, transparent);
    border-radius: 10px;
    padding: 12px;
    background: color-mix(in srgb, var(--surface-color) 95%, var(--bg-color));
}

.repo-detail-title {
    margin: 0;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.11em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.repo-description {
    margin: 9px 0 0;
    font-size: 12px;
    line-height: 1.45;
    color: var(--text-color);
    white-space: pre-wrap;
    word-break: break-word;
}

.repo-tag-list {
    margin-top: 9px;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.repo-tag {
    display: inline-flex;
    align-items: center;
    max-width: 100%;
    height: 22px;
    padding: 0 9px;
    border-radius: 999px;
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 11px;
    color: var(--branch-node-color);
    border: 1px solid color-mix(in srgb, var(--branch-node-color) 34%, var(--border-color));
    background: color-mix(in srgb, var(--branch-node-color) 11%, transparent);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.repo-tag--empty {
    color: var(--text-secondary);
    border-color: color-mix(in srgb, var(--border-color) 84%, transparent);
    background: color-mix(in srgb, var(--surface-color) 90%, transparent);
}

.repo-remote-list {
    list-style: none;
    margin: 9px 0 0;
    padding: 0;
    display: grid;
    gap: 6px;
}

.repo-remote {
    display: grid;
    grid-template-columns: auto auto 1fr;
    gap: 7px;
    align-items: center;
    padding: 8px 9px;
    border: 1px solid color-mix(in srgb, var(--border-color) 90%, transparent);
    border-radius: 8px;
    background: color-mix(in srgb, var(--surface-color) 94%, transparent);
}

.repo-remote-name {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.repo-remote-host {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 11px;
    color: var(--node-color);
}

.repo-remote-path {
    min-width: 0;
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 11px;
    color: var(--text-color);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.repo-remote--empty {
    display: block;
    font-size: 12px;
    color: var(--text-secondary);
    text-align: center;
}

@media (max-width: 520px) {
    .repo-metric-grid {
        grid-template-columns: 1fr;
    }

    .repo-overview-title {
        font-size: 17px;
    }
}

/* ── File Sidebar (Right) ── */

.file-sidebar {
    position: relative;
    display: flex;
    flex-direction: column;
    background: var(--surface-elevated);
    border-left: 1px solid var(--border-color);
    overflow: hidden;
    transition: width 0.2s ease, min-width 0.2s ease;
}

.file-sidebar.is-resizing {
    transition: none;
}

.file-sidebar.is-collapsed {
    border-left: none;
}

.file-sidebar.is-collapsed .file-sidebar-header,
.file-sidebar.is-collapsed .file-sidebar-content,
.file-sidebar.is-collapsed .file-sidebar-handle {
    display: none;
}

.file-sidebar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 12px;
    border-bottom: 1px solid var(--border-color);
    flex-shrink: 0;
}

.file-sidebar-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-color);
}

.file-sidebar-close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    border: none;
    border-radius: 6px;
    background: transparent;
    color: var(--text-color);
    cursor: pointer;
    transition: background-color 0.15s ease;
}

.file-sidebar-close:hover {
    background: rgba(208, 215, 222, 0.32);
}

@media (prefers-color-scheme: dark) {
    .file-sidebar-close:hover {
        background: rgba(48, 54, 61, 0.8);
    }
}

.file-sidebar-content {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
}

.file-sidebar-handle {
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    cursor: col-resize;
    z-index: 20;
}

.file-sidebar-handle:hover,
.file-sidebar.is-resizing .file-sidebar-handle {
    background: var(--node-color);
    opacity: 0.5;
}

/* ── File Browser ── */

.file-browser {
    display: flex;
    flex-direction: column;
    height: 100%;
}

/* Breadcrumbs */

.file-breadcrumbs {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 8px 12px;
    border-bottom: 1px solid var(--border-color);
    background: var(--surface-elevated);
    flex-wrap: wrap;
    flex-shrink: 0;
}

.file-breadcrumb {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 12px;
    padding: 4px 8px;
    border: none;
    border-radius: 6px;
    background: transparent;
    color: var(--node-color);
    cursor: pointer;
    transition: all 0.12s ease;
    font-weight: 500;
}

.file-breadcrumb:hover {
    background: rgba(14, 165, 233, 0.08);
}

@media (prefers-color-scheme: dark) {
    .file-breadcrumb:hover {
        background: rgba(88, 166, 255, 0.12);
    }
}

.file-breadcrumb-current {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 12px;
    padding: 3px 6px;
    color: var(--text-color);
    font-weight: 600;
}

.file-breadcrumb-sep {
    font-size: 12px;
    color: var(--text-secondary);
}

/* Tree Listing */

.file-tree {
    flex: 1;
    overflow-y: auto;
    padding: 4px;
}

.file-tree-entry {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 7px 8px;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.12s ease;
}

.file-tree-entry:hover {
    background: rgba(14, 165, 233, 0.08);
    color: var(--node-color);
}

@media (prefers-color-scheme: dark) {
    .file-tree-entry:hover {
        background: rgba(48, 54, 61, 0.6);
    }
}

.file-tree-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--text-color);
    opacity: 0.7;
}

.file-tree-name {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 13px;
    color: var(--text-color);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.file-tree-empty {
    padding: 16px 12px;
    text-align: center;
    font-size: 13px;
    color: var(--text-secondary);
}

/* File Content Viewer */

.file-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.file-content-back {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 5px 10px;
    margin: 8px 12px 0;
    border: none;
    border-radius: 4px;
    background: transparent;
    color: var(--text-secondary);
    font-family: 'Geist', sans-serif;
    font-size: 12px;
    font-weight: 500;
    cursor: pointer;
    transition: color 0.15s, background 0.15s;
    align-self: flex-start;
}

.file-content-back:hover {
    background: rgba(128, 128, 128, 0.1);
    color: var(--text-color);
}

.file-content-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    border-bottom: 1px solid var(--border-color);
    background: var(--surface-color);
    flex-shrink: 0;
}

.file-content-filename {
    display: flex;
    align-items: center;
    gap: 6px;
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 13px;
    font-weight: 600;
    color: var(--text-color);
}

.file-content-meta {
    font-size: 11px;
    color: var(--text-secondary);
    margin-left: auto;
    font-variant-numeric: tabular-nums;
}

.file-content-body {
    flex: 1;
    overflow: auto;
    display: flex;
    align-items: stretch;
    background: var(--surface-color);
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 12px;
    line-height: 1.6;
}

.file-content-linenums {
    flex-shrink: 0;
    margin: 0;
    padding: 10px 0;
    text-align: right;
    user-select: none;
    font-variant-numeric: tabular-nums;
    position: sticky;
    left: 0;
    z-index: 1;
    background: var(--surface-color);
    border-right: 1px solid var(--border-color);
    box-shadow: 2px 0 8px -2px rgba(0, 0, 0, 0.05);
}

@media (prefers-color-scheme: dark) {
    .file-content-linenums {
        box-shadow: 2px 0 8px -2px rgba(0, 0, 0, 0.25);
    }
}

.file-content-linenum {
    display: block;
    padding: 0 12px;
    color: var(--text-secondary);
    opacity: 0.5;
    transition: opacity 0.15s;
}

.file-content-linenums:hover .file-content-linenum {
    opacity: 0.85;
}

.file-content-pre {
    flex: 1;
    margin: 0;
    padding: 10px 16px;
    min-width: 0;
}

.file-content-pre code {
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
    padding: 0 !important;
    background: transparent !important;
}

.file-content-binary {
    padding: 24px 12px;
    text-align: center;
    color: var(--text-secondary);
    font-size: 13px;
}

.file-content-truncated {
    padding: 12px;
    background: rgba(154, 103, 0, 0.12);
    border-top: 1px solid rgba(154, 103, 0, 0.3);
    color: var(--warning-color);
    font-size: 12px;
    text-align: center;
}

@media (prefers-color-scheme: dark) {
    .file-content-truncated {
        background: rgba(210, 153, 34, 0.12);
        border-top: 1px solid rgba(210, 153, 34, 0.3);
    }
}

.file-content-loading {
    padding: 40px 12px;
    text-align: center;
    color: var(--text-secondary);
    font-size: 13px;
    animation: file-content-pulse 1.5s ease-in-out infinite;
}

@keyframes file-content-pulse {
    0%, 100% { opacity: 0.4; }
    50% { opacity: 1; }
}

.file-content-error {
    padding: 24px 12px;
    text-align: center;
    color: var(--danger-color);
    font-size: 13px;
}

/* ── File Explorer Toolbar ── */

.file-explorer-toolbar {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 8px;
    border-bottom: 1px solid var(--border-color);
    flex-shrink: 0;
}

.file-explorer-toolbar > button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    border: none;
    border-radius: 4px;
    background: transparent;
    color: var(--text-secondary);
    cursor: pointer;
    flex-shrink: 0;
    transition: background-color 0.1s ease, color 0.1s ease;
}

.file-explorer-toolbar > button:hover {
    background: rgba(208, 215, 222, 0.32);
    color: var(--text-color);
}

@media (prefers-color-scheme: dark) {
    .file-explorer-toolbar > button:hover {
        background: rgba(48, 54, 61, 0.6);
    }
}

.file-explorer-filter {
    flex: 1;
    display: flex;
    align-items: center;
    position: relative;
    min-width: 0;
}

.file-explorer-filter-icon {
    position: absolute;
    left: 6px;
    display: inline-flex;
    color: var(--text-secondary);
    pointer-events: none;
}

.file-explorer-filter input {
    width: 100%;
    padding: 4px 24px 4px 24px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--surface-color);
    color: var(--text-color);
    font-size: 11px;
    font-family: inherit;
    outline: none;
    transition: all 0.15s ease;
}

.file-explorer-filter input:focus {
    border-color: var(--node-color);
    box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.1);
}

.file-explorer-filter input::placeholder {
    color: var(--text-secondary);
    opacity: 0.6;
}

.file-explorer-filter-clear {
    position: absolute;
    right: 2px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    border: none;
    border-radius: 3px;
    background: transparent;
    color: var(--text-secondary);
    cursor: pointer;
    padding: 0;
}

.file-explorer-filter-clear:hover {
    color: var(--text-color);
}

/* ── File Explorer Breadcrumbs ── */

.file-explorer-breadcrumbs {
    display: flex;
    align-items: center;
    gap: 2px;
    padding: 4px 8px;
    border-bottom: 1px solid var(--border-color);
    flex-shrink: 0;
    flex-wrap: wrap;
}

/* ── File Explorer Animations ── */

@keyframes explorer-entry-appear {
    from {
        opacity: 0;
        transform: translateY(-4px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.explorer-entry.is-new {
    animation: explorer-entry-appear 0.15s ease-out;
}

/* ── File Explorer Skeleton Loading ── */

@keyframes skeleton-pulse {
    0%, 100% { opacity: 0.4; }
    50% { opacity: 0.8; }
}

.explorer-skeleton {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 3px 8px;
    margin: 0 4px;
    height: 24px;
}

.explorer-skeleton-icon {
    width: 14px;
    height: 14px;
    border-radius: 3px;
    background: var(--border-color);
    flex-shrink: 0;
    animation: skeleton-pulse 1.2s ease-in-out infinite;
}

.explorer-skeleton-bar {
    height: 10px;
    border-radius: 3px;
    background: var(--border-color);
    animation: skeleton-pulse 1.2s ease-in-out infinite;
}

.explorer-blame-skeleton {
    display: inline-block;
    width: 36px;
    height: 8px;
    border-radius: 2px;
    background: var(--border-color);
    animation: skeleton-pulse 1.2s ease-in-out infinite;
}

/* ── File Explorer Empty State ── */

.file-explorer-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 48px 16px;
    flex: 1;
}

.file-explorer-empty-icon {
    color: var(--text-secondary);
    opacity: 0.3;
}

.file-explorer-empty-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-secondary);
}

.file-explorer-empty-hint {
    font-size: 12px;
    color: var(--text-secondary);
    opacity: 0.6;
}

/* ── File Explorer Git Status Badges ── */

.explorer-status {
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 11px;
    font-weight: 700;
    padding: 0 4px;
    border-radius: 3px;
    flex-shrink: 0;
    line-height: 16px;
}

.explorer-status--staged {
    background: rgba(26, 127, 55, 0.15);
    color: var(--success-color);
}

.explorer-status--modified {
    background: rgba(154, 103, 0, 0.15);
    color: var(--warning-color);
}

.explorer-status--untracked {
    background: rgba(208, 215, 222, 0.32);
    color: var(--text-secondary);
}

.explorer-status--deleted {
    background: rgba(209, 36, 47, 0.15);
    color: var(--danger-color);
}

@media (prefers-color-scheme: dark) {
    .explorer-status--staged {
        background: rgba(63, 185, 80, 0.15);
    }

    .explorer-status--modified {
        background: rgba(210, 153, 34, 0.15);
    }

    .explorer-status--untracked {
        background: rgba(48, 54, 61, 0.6);
    }

    .explorer-status--deleted {
        background: rgba(248, 81, 73, 0.15);
    }
}

.explorer-dir-indicator {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    flex-shrink: 0;
    background: var(--warning-color);
}

/* ── Diff Content Viewer ── */

.diff-content-viewer {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.diff-content-back {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 12px;
    margin: 10px 12px 0;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--surface-elevated);
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.15s ease;
    align-self: flex-start;
}

.diff-content-back:hover {
    background: rgba(14, 165, 233, 0.08);
    color: var(--node-color);
    border-color: var(--node-color);
}

@media (prefers-color-scheme: dark) {
    .diff-content-back:hover {
        background: rgba(48, 54, 61, 0.6);
    }
}

.diff-file-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    border-bottom: 1px solid var(--border-color);
    background: var(--surface-elevated);
    flex-shrink: 0;
}

.diff-status-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    border-radius: 4px;
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 11px;
    font-weight: 700;
    flex-shrink: 0;
    background: rgba(208, 215, 222, 0.32);
    color: var(--text-secondary);
}

@media (prefers-color-scheme: dark) {
    .diff-status-badge {
        background: rgba(48, 54, 61, 0.6);
    }
}

.diff-status-badge--added {
    background: rgba(26, 127, 55, 0.15);
    color: var(--success-color);
}

.diff-status-badge--modified {
    background: rgba(154, 103, 0, 0.15);
    color: var(--warning-color);
}

.diff-status-badge--deleted {
    background: rgba(209, 36, 47, 0.15);
    color: var(--danger-color);
}

.diff-status-badge--renamed {
    background: rgba(9, 105, 218, 0.15);
    color: var(--node-color);
}

.diff-status-badge--copied {
    background: rgba(9, 105, 218, 0.15);
    color: var(--node-color);
}

@media (prefers-color-scheme: dark) {
    .diff-status-badge--added {
        background: rgba(63, 185, 80, 0.15);
    }

    .diff-status-badge--modified {
        background: rgba(210, 153, 34, 0.15);
    }

    .diff-status-badge--deleted {
        background: rgba(248, 81, 73, 0.15);
    }

    .diff-status-badge--renamed {
        background: rgba(88, 166, 255, 0.15);
    }

    .diff-status-badge--copied {
        background: rgba(88, 166, 255, 0.15);
    }
}

.diff-file-path {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 13px;
    font-weight: 600;
    color: var(--text-color);
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.diff-content-body {
    flex: 1;
    overflow-y: auto;
    overflow-x: auto;
    background: var(--surface-elevated);
}

.diff-hunks {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 12px;
    line-height: 1.5;
    min-width: fit-content;
}

.diff-hunk {
    margin: 0;
}

.diff-hunk-header {
    padding: 6px 12px;
    background: rgba(88, 166, 255, 0.08);
    color: var(--node-color);
    font-weight: 600;
    border-top: 1px solid var(--border-color);
    border-bottom: 1px solid var(--border-color);
    user-select: none;
}

@media (prefers-color-scheme: dark) {
    .diff-hunk-header {
        background: rgba(88, 166, 255, 0.12);
    }
}

.diff-line {
    display: flex;
    align-items: stretch;
}

.diff-line:hover {
    background: rgba(208, 215, 222, 0.16);
}

@media (prefers-color-scheme: dark) {
    .diff-line:hover {
        background: rgba(48, 54, 61, 0.3);
    }
}

/* Line number gutters — sticky so they stay visible on horizontal scroll */
.line-num-old,
.line-num-new {
    flex-shrink: 0;
    width: 40px;
    padding: 1px 6px;
    text-align: right;
    color: var(--text-secondary);
    user-select: none;
    font-variant-numeric: tabular-nums;
    position: sticky;
    z-index: 2;
    background-color: var(--surface-elevated);
}

.line-num-old {
    left: 0;
    border-right: 1px solid var(--border-color);
}

.line-num-new {
    left: 53px;
    border-right: 1px solid var(--border-color);
}

.line-content {
    flex: 1 0 auto;
    padding: 1px 8px;
    white-space: pre;
}

/* Line type styling */
.diff-line-add {
    background: rgba(26, 127, 55, 0.08);
}

.diff-line-add:hover {
    background: rgba(26, 127, 55, 0.12);
}

.diff-line-add .line-num-old,
.diff-line-add .line-num-new {
    background-color: var(--surface-elevated);
    background-image: linear-gradient(rgba(26, 127, 55, 0.12) 0 0);
}

.diff-line-delete {
    background: rgba(209, 36, 47, 0.08);
}

.diff-line-delete:hover {
    background: rgba(209, 36, 47, 0.12);
}

.diff-line-delete .line-num-old,
.diff-line-delete .line-num-new {
    background-color: var(--surface-elevated);
    background-image: linear-gradient(rgba(209, 36, 47, 0.12) 0 0);
}

.diff-line-context {
    background: transparent;
}

@media (prefers-color-scheme: dark) {
    .diff-line-add {
        background: rgba(63, 185, 80, 0.1);
    }

    .diff-line-add:hover {
        background: rgba(63, 185, 80, 0.14);
    }

    .diff-line-add .line-num-old,
    .diff-line-add .line-num-new {
        background-color: var(--surface-elevated);
        background-image: linear-gradient(rgba(63, 185, 80, 0.15) 0 0);
    }

    .diff-line-delete {
        background: rgba(248, 81, 73, 0.1);
    }

    .diff-line-delete:hover {
        background: rgba(248, 81, 73, 0.14);
    }

    .diff-line-delete .line-num-old,
    .diff-line-delete .line-num-new {
        background-color: var(--surface-elevated);
        background-image: linear-gradient(rgba(248, 81, 73, 0.15) 0 0);
    }
}

/* Hover tint on sticky line number gutters for context lines */
.diff-line-context:hover .line-num-old,
.diff-line-context:hover .line-num-new {
    background-image: linear-gradient(rgba(208, 215, 222, 0.16) 0 0);
}

@media (prefers-color-scheme: dark) {
    .diff-line-context:hover .line-num-old,
    .diff-line-context:hover .line-num-new {
        background-image: linear-gradient(rgba(48, 54, 61, 0.3) 0 0);
    }
}

/* Expand context button between non-adjacent hunks */
.diff-expand-context {
    display: block;
    width: 100%;
    padding: 6px 12px;
    background: rgba(88, 166, 255, 0.04);
    border: none;
    border-top: 1px solid var(--border-color);
    border-bottom: 1px solid var(--border-color);
    color: var(--node-color);
    font-size: 12px;
    font-weight: 500;
    font-family: inherit;
    cursor: pointer;
    transition: background 0.15s ease;
}

.diff-expand-context:hover {
    background: rgba(88, 166, 255, 0.1);
}

@media (prefers-color-scheme: dark) {
    .diff-expand-context {
        background: rgba(88, 166, 255, 0.06);
    }

    .diff-expand-context:hover {
        background: rgba(88, 166, 255, 0.14);
    }
}

/* ── Syntax highlighting inside diff lines ── */

/*
 * .diff-prefix: the +/-/space indicator column between line numbers and code.
 * Rendered as its own flex child so it forms a clean visual column.
 */
.diff-prefix {
    flex-shrink: 0;
    width: 20px;
    text-align: center;
    user-select: none;
    color: var(--text-secondary);
    font-weight: 500;
}

.diff-line-add .diff-prefix {
    color: var(--success-color);
}

.diff-line-delete .diff-prefix {
    color: var(--danger-color);
}

/*
 * .diff-source: the container for the hljs-highlighted code fragment.
 * Inline so it flows naturally inside the line-content span.
 */
.diff-source {
    display: inline;
}

/*
 * Reduce hljs token intensity inside diff lines.
 *
 * In a unified diff the diff status (green/red background) is the primary
 * visual signal.  Syntax colors are secondary, so we pull them back slightly.
 * Using opacity rather than desaturation preserves readability while ensuring
 * the diff background tint always reads through.
 *
 * The attribute selector [class^="hljs-"] matches all hljs token spans
 * regardless of which theme is active.
 */
.diff-line .line-content [class^="hljs-"] {
    opacity: 0.88;
}

/* File notices */
.diff-file-notice {
    padding: 12px 12px;
    text-align: center;
    font-size: 12px;
    font-weight: 600;
    border-bottom: 1px solid var(--border-color);
}

.diff-file-notice--added {
    background: rgba(26, 127, 55, 0.08);
    color: var(--success-color);
}

.diff-file-notice--deleted {
    background: rgba(209, 36, 47, 0.08);
    color: var(--danger-color);
}

@media (prefers-color-scheme: dark) {
    .diff-file-notice--added {
        background: rgba(63, 185, 80, 0.1);
    }

    .diff-file-notice--deleted {
        background: rgba(248, 81, 73, 0.1);
    }
}

.diff-binary-notice {
    padding: 24px 12px;
    text-align: center;
    color: var(--text-secondary);
    font-size: 13px;
}

.diff-truncated-notice {
    padding: 12px;
    background: rgba(154, 103, 0, 0.12);
    border-top: 1px solid rgba(154, 103, 0, 0.3);
    color: var(--warning-color);
    font-size: 12px;
    text-align: center;
    font-weight: 500;
}

@media (prefers-color-scheme: dark) {
    .diff-truncated-notice {
        background: rgba(210, 153, 34, 0.12);
        border-top: 1px solid rgba(210, 153, 34, 0.3);
    }
}

/* ── Diff View ── */

.diff-view {
    display: flex;
    flex-direction: column;
    height: 100%;
    background: var(--surface-elevated);
    overflow: hidden;
}

.diff-view-header {
    padding: 12px 16px;
    border-bottom: 1px solid var(--border-color);
    background: var(--surface-elevated);
    flex-shrink: 0;
}

.diff-view-commit-info {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-color);
}

/* Stats bar showing file change counts */
.diff-stats-bar {
    display: flex;
    gap: 12px;
    padding: 8px 16px;
    border-bottom: 1px solid var(--border-color);
    background: var(--bg-color);
    font-size: 12px;
    flex-shrink: 0;
}

.diff-stat {
    font-weight: 600;
}

.diff-stat--added {
    color: var(--success-color);
}

.diff-stat--modified {
    color: var(--warning-color);
}

.diff-stat--deleted {
    color: var(--danger-color);
}

.diff-stat-total {
    margin-left: auto;
    color: var(--text-secondary);
}

/* File list container */
.diff-file-list-container {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.diff-file-list-heading {
    padding: 12px 16px;
    font-size: 13px;
    font-weight: 600;
    color: var(--text-color);
    border-bottom: 1px solid var(--border-color);
    flex-shrink: 0;
}

.diff-file-list {
    flex: 1;
    overflow-y: auto;
}

.diff-file-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    cursor: pointer;
    border-bottom: 1px solid var(--border-color);
    transition: all 0.12s ease;
}

.diff-file-item:hover {
    background: rgba(14, 165, 233, 0.05);
}

.diff-file-item.is-selected {
    background: rgba(14, 165, 233, 0.1);
    border-left: 3px solid var(--node-color);
    padding-left: 13px;
    font-weight: 500;
}

@media (prefers-color-scheme: dark) {
    .diff-file-item.is-selected {
        background: rgba(88, 166, 255, 0.12);
    }
}

/* Status badges (A, M, D, R) */
.diff-status {
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 11px;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 3px;
    text-align: center;
    min-width: 20px;
    flex-shrink: 0;
}

.diff-status--added {
    background: rgba(26, 127, 55, 0.15);
    color: var(--success-color);
}

.diff-status--modified {
    background: rgba(154, 103, 0, 0.15);
    color: var(--warning-color);
}

.diff-status--deleted {
    background: rgba(209, 36, 47, 0.15);
    color: var(--danger-color);
}

.diff-status--renamed {
    background: rgba(9, 105, 218, 0.15);
    color: var(--node-color);
}

.diff-status--unknown {
    background: rgba(208, 215, 222, 0.32);
    color: var(--text-secondary);
}

@media (prefers-color-scheme: dark) {
    .diff-status--added {
        background: rgba(63, 185, 80, 0.15);
    }

    .diff-status--modified {
        background: rgba(210, 153, 34, 0.15);
    }

    .diff-status--deleted {
        background: rgba(248, 81, 73, 0.15);
    }

    .diff-status--renamed {
        background: rgba(88, 166, 255, 0.15);
    }

    .diff-status--unknown {
        background: rgba(48, 54, 61, 0.6);
    }
}

.diff-file-icon {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    color: var(--text-secondary);
}

.diff-file-item .diff-file-path {
    flex: 1;
    font-size: 13px;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    color: var(--text-color);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.diff-file-binary-badge {
    font-size: 11px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 3px;
    background: rgba(208, 215, 222, 0.32);
    color: var(--text-secondary);
    flex-shrink: 0;
}

@media (prefers-color-scheme: dark) {
    .diff-file-binary-badge {
        background: rgba(48, 54, 61, 0.6);
    }
}

/* Loading state */
.diff-view-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex: 1;
    gap: 16px;
}

.diff-loading-spinner {
    width: 36px;
    height: 36px;
    border: 3px solid var(--border-color);
    border-top-color: var(--node-color);
    border-radius: 50%;
    animation: diff-spin 0.9s cubic-bezier(0.4, 0.0, 0.6, 1.0) infinite;
}

@keyframes diff-spin {
    to {
        transform: rotate(360deg);
    }
}

.diff-loading-text {
    font-size: 13px;
    color: var(--text-secondary);
}

/* Empty state */
.diff-view-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex: 1;
    gap: 12px;
    padding: 40px;
    text-align: center;
}

.diff-empty-icon {
    color: var(--text-secondary);
    opacity: 0.3;
}

.diff-empty-title {
    font-size: 15px;
    font-weight: 600;
    color: var(--text-color);
}

.diff-empty-hint {
    font-size: 13px;
    color: var(--text-secondary);
}

/* Error state */
.diff-view-error {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex: 1;
    gap: 12px;
    padding: 40px;
    text-align: center;
}

.diff-error-icon {
    color: var(--danger-color);
    opacity: 0.8;
}

.diff-error-title {
    font-size: 15px;
    font-weight: 600;
    color: var(--danger-color);
}

.diff-error-hint {
    font-size: 13px;
    color: var(--text-secondary);
}

/* ── Graph Filter Popover ── */

.graph-filter-wrapper {
    position: relative;
    flex-shrink: 0;
}

/* Trigger button — sits in the canvas toolbar */
.graph-filter-trigger {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    height: 32px;
    padding: 0 10px;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    background: transparent;
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 500;
    font-family: inherit;
    cursor: pointer;
    transition: all 0.15s ease;
    flex-shrink: 0;
    white-space: nowrap;
}

.graph-filter-trigger:hover {
    color: var(--text-color);
    border-color: var(--text-secondary);
    background: rgba(208, 215, 222, 0.16);
}

@media (prefers-color-scheme: dark) {
    .graph-filter-trigger:hover {
        background: rgba(48, 54, 61, 0.5);
    }
}

.graph-filter-trigger.is-active {
    color: var(--node-color);
    border-color: var(--node-color);
    background: rgba(14, 165, 233, 0.06);
}

@media (prefers-color-scheme: dark) {
    .graph-filter-trigger.is-active {
        background: rgba(88, 166, 255, 0.08);
    }
}

.graph-filter-trigger.has-active-filters {
    color: var(--node-color);
    border-color: var(--node-color);
}

/* Small dot indicator when filters are active */
.graph-filter-trigger.has-active-filters .graph-filter-trigger-icon::after {
    content: "";
    position: absolute;
    top: -2px;
    right: -5px;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--node-color);
}

.graph-filter-trigger:focus-visible {
    outline: 2px solid var(--node-color);
    outline-offset: 2px;
}

.graph-filter-trigger-icon {
    position: relative;
    display: inline-flex;
    align-items: center;
}

.graph-filter-trigger-label {
    line-height: 1;
}

/* Popover panel — drops below the trigger */
.graph-filter-popover {
    display: none;
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    z-index: 50;
    min-width: 240px;
    background: var(--surface-elevated);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    box-shadow: var(--surface-elevated-shadow);
    overflow: hidden;
}

.graph-filter-popover.is-open {
    display: block;
}

/* Popover header */
.graph-filter-popover-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 14px;
    border-bottom: 1px solid var(--border-color);
}

.graph-filter-popover-title {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-color);
    letter-spacing: 0.02em;
}

.graph-filter-reset {
    font-size: 11px;
    font-weight: 500;
    font-family: inherit;
    color: var(--node-color);
    background: none;
    border: none;
    cursor: pointer;
    padding: 2px 6px;
    border-radius: 4px;
    transition: background-color 0.12s ease;
}

.graph-filter-reset:hover {
    background: rgba(14, 165, 233, 0.1);
}

@media (prefers-color-scheme: dark) {
    .graph-filter-reset:hover {
        background: rgba(88, 166, 255, 0.12);
    }
}

/* Popover body */
.graph-filter-popover-body {
    padding: 8px 0;
}

/* Section within popover */
.graph-filter-section {
    padding: 4px 14px 8px;
}

.graph-filter-section + .graph-filter-section {
    border-top: 1px solid var(--border-color);
    padding-top: 8px;
}

.graph-filter-section-label {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-secondary);
    margin-bottom: 6px;
}

/* Checkbox toggle */
.graph-filter-toggle {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--text-color);
    cursor: pointer;
    user-select: none;
    padding: 5px 0;
    white-space: nowrap;
    transition: color 0.1s ease;
}

.graph-filter-toggle:hover {
    color: var(--node-color);
}

.graph-filter-toggle input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 15px;
    height: 15px;
    border: 1.5px solid var(--border-color);
    border-radius: 4px;
    background: var(--surface-color);
    cursor: pointer;
    flex-shrink: 0;
    position: relative;
    transition: background-color 0.12s ease, border-color 0.12s ease;
}

.graph-filter-toggle input[type="checkbox"]:checked {
    background: var(--node-color);
    border-color: var(--node-color);
}

.graph-filter-toggle input[type="checkbox"]:checked::after {
    content: "";
    position: absolute;
    left: 3px;
    top: 0;
    width: 5px;
    height: 9px;
    border: 2px solid #ffffff;
    border-top: none;
    border-left: none;
    transform: rotate(45deg);
}

.graph-filter-toggle input[type="checkbox"]:focus-visible {
    outline: 2px solid var(--node-color);
    outline-offset: 2px;
}

.graph-filter-toggle:hover input[type="checkbox"]:not(:checked) {
    border-color: var(--node-color);
}

/* Branch dropdown */
.graph-filter-dropdown {
    width: 100%;
    font-size: 13px;
    font-family: inherit;
    padding: 6px 28px 6px 10px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--surface-color);
    color: var(--text-color);
    cursor: pointer;
    outline: none;
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238b949e' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    transition: border-color 0.12s ease, box-shadow 0.12s ease;
}

.graph-filter-dropdown:hover {
    border-color: var(--node-color);
}

.graph-filter-dropdown:focus {
    border-color: var(--node-color);
    box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.12);
}

@media (prefers-color-scheme: dark) {
    .graph-filter-dropdown {
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238b8f96' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E");
    }

    .graph-filter-dropdown:focus {
        box-shadow: 0 0 0 2px rgba(88, 166, 255, 0.15);
    }
}

/* ── Repo Landing Page (hosted mode) ──────────────────────────────────── */

.repo-landing {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    padding: 0 24px 0;
    min-height: 100vh;
    background: var(--bg-color);
    color: var(--text-color);
    font-family: 'Geist', -apple-system, BlinkMacSystemFont, sans-serif;
    overflow-y: auto;
}

/* ── Hero ── */

.repo-landing__hero {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 80px 0 64px;
    width: 100%;
    max-width: 960px;
}

.repo-landing__logo {
    margin-bottom: 20px;
    line-height: 0;
}

.repo-landing__title {
    font-size: 48px;
    font-weight: 700;
    margin: 0 0 12px;
    letter-spacing: -1px;
}

.repo-landing__tagline {
    font-size: 18px;
    color: var(--text-secondary);
    margin: 0 0 32px;
}

.repo-landing__hero-actions {
    display: flex;
    gap: 12px;
}

.repo-landing__cta-primary {
    padding: 12px 28px;
    font-size: 15px;
    font-weight: 600;
    font-family: inherit;
    border: none;
    border-radius: 8px;
    background: var(--node-color);
    color: #fff;
    cursor: pointer;
    transition: opacity 150ms ease;
}

.repo-landing__cta-primary:hover {
    opacity: 0.9;
}

.repo-landing__cta-secondary {
    padding: 12px 28px;
    font-size: 15px;
    font-weight: 600;
    font-family: inherit;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    background: transparent;
    color: var(--text-color);
    cursor: pointer;
    transition: border-color 150ms ease, color 150ms ease;
}

.repo-landing__cta-secondary:hover {
    border-color: var(--text-secondary);
}

/* ── Sections ── */

.repo-landing__section {
    width: 100%;
    max-width: 960px;
    padding: 48px 0;
}

.repo-landing__section-title {
    font-size: 22px;
    font-weight: 700;
    margin: 0 0 6px;
    letter-spacing: -0.3px;
}

.repo-landing__section-subtitle {
    font-size: 14px;
    color: var(--text-secondary);
    margin: 0 0 24px;
}

/* ── Featured Grid ── */

.repo-landing__featured-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 16px;
}

.repo-landing__card {
    display: flex;
    flex-direction: column;
    padding: 20px;
    border-radius: 10px;
    background: var(--surface-color);
    border: 1px solid var(--border-color);
    transition: border-color 200ms ease, box-shadow 200ms ease, outline 300ms ease;
}

.repo-landing__card--ready {
    cursor: pointer;
}

.repo-landing__card--ready:hover {
    border-color: var(--node-color);
    box-shadow: 0 2px 12px rgba(14, 165, 233, 0.1);
}

.repo-landing__card--loading {
    opacity: 0.85;
}

.repo-landing__card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 8px;
}

.repo-landing__card-name {
    font-family: 'JetBrains Mono', monospace;
    font-size: 14px;
    font-weight: 600;
}

.repo-landing__card-desc {
    font-size: 13px;
    color: var(--text-secondary);
    margin: 0 0 16px;
    line-height: 1.5;
    flex: 1;
}

.repo-landing__card-action {
    display: flex;
    align-items: center;
    gap: 10px;
}

.repo-landing__card-cta {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    font-size: 13px;
    font-weight: 600;
    font-family: inherit;
    border: none;
    border-radius: 6px;
    background: var(--node-color);
    color: #fff;
    cursor: pointer;
    transition: opacity 150ms ease;
}

.repo-landing__card-cta:hover {
    opacity: 0.9;
}

.repo-landing__card-progress {
    font-size: 13px;
    color: var(--text-secondary);
}

.repo-landing__clone-progress {
    display: flex;
    flex-direction: column;
    gap: 4px;
    width: 100%;
}

.repo-landing__progress-bar {
    width: 100%;
    height: 4px;
    background: var(--border-color);
    border-radius: 2px;
    overflow: hidden;
}

.repo-landing__progress-fill {
    height: 100%;
    background: var(--node-color);
    border-radius: 2px;
    transition: width 150ms ease;
}

/* ── Try Your Own (form + list) ── */

.repo-landing__form {
    display: flex;
    gap: 8px;
    width: 100%;
    max-width: 520px;
    margin-bottom: 8px;
}

.repo-landing__input {
    flex: 1;
    padding: 10px 14px;
    font-size: 14px;
    font-family: inherit;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    background: var(--surface-color);
    color: var(--text-color);
    outline: none;
    transition: border-color 150ms ease;
}

.repo-landing__input:focus {
    border-color: var(--node-color);
    box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.15);
}

.repo-landing__add-btn {
    padding: 10px 20px;
    font-size: 14px;
    font-weight: 600;
    font-family: inherit;
    border: none;
    border-radius: 8px;
    background: var(--node-color);
    color: #fff;
    cursor: pointer;
    white-space: nowrap;
    transition: opacity 150ms ease;
}

.repo-landing__add-btn:hover {
    opacity: 0.9;
}

.repo-landing__add-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.repo-landing__error {
    font-size: 13px;
    color: var(--danger-color);
    min-height: 20px;
    max-width: 520px;
    width: 100%;
    text-align: left;
}

.repo-landing__list {
    width: 100%;
    max-width: 520px;
    margin-top: 16px;
}

.repo-landing__list-heading {
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--text-secondary);
    margin: 0 0 8px;
}

.repo-landing__item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 14px;
    margin-bottom: 6px;
    border-radius: 8px;
    background: var(--surface-color);
    border: 1px solid var(--border-color);
    transition: border-color 150ms ease, box-shadow 150ms ease;
}

.repo-landing__item--ready {
    cursor: pointer;
}

.repo-landing__item--ready:hover {
    border-color: var(--node-color);
    box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.1);
}

.repo-landing__item-info {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
    flex: 1;
}

.repo-landing__item-url {
    font-size: 14px;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
}

.repo-landing__badge {
    font-size: 11px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 10px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    flex-shrink: 0;
}

.repo-landing__badge--pending {
    background: rgba(14, 165, 233, 0.12);
    color: var(--node-color);
}

.repo-landing__badge--cloning {
    background: rgba(217, 119, 6, 0.15);
    color: var(--warning-color);
}

.repo-landing__badge--ready {
    background: rgba(5, 150, 105, 0.15);
    color: var(--success-color);
}

.repo-landing__badge--error {
    background: rgba(220, 38, 38, 0.15);
    color: var(--danger-color);
}

.repo-landing__item-error {
    font-size: 12px;
    color: var(--danger-color);
}

.repo-landing__delete-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border: none;
    border-radius: 6px;
    background: transparent;
    color: var(--text-secondary);
    cursor: pointer;
    flex-shrink: 0;
    transition: background 150ms ease, color 150ms ease;
}

.repo-landing__delete-btn:hover {
    background: rgba(220, 38, 38, 0.1);
    color: var(--danger-color);
}

/* ── Install Section ── */

.repo-landing__code-block {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    border-radius: 8px;
    background: var(--surface-color);
    border: 1px solid var(--border-color);
    max-width: 620px;
}

.repo-landing__code-block code {
    flex: 1;
    font-family: 'JetBrains Mono', monospace;
    font-size: 13px;
    white-space: nowrap;
    overflow-x: auto;
    color: var(--text-color);
}

.repo-landing__copy-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border: none;
    border-radius: 6px;
    background: transparent;
    color: var(--text-secondary);
    cursor: pointer;
    flex-shrink: 0;
    transition: background 150ms ease, color 150ms ease;
}

.repo-landing__copy-btn:hover {
    background: var(--surface-recessed);
    color: var(--text-color);
}

/* ── Footer ── */

.repo-landing__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    max-width: 960px;
    padding: 24px 0;
    margin-top: 24px;
    border-top: 1px solid var(--border-color);
}

.repo-landing__footer-links {
    display: flex;
    align-items: center;
    gap: 16px;
}

.repo-landing__footer-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--text-secondary);
    text-decoration: none;
    transition: color 150ms ease;
}

.repo-landing__footer-link:hover {
    color: var(--text-color);
}

.repo-landing__footer-license {
    font-size: 12px;
    color: var(--text-secondary);
}

/* ── Responsive ── */

@media (max-width: 480px) {
    .repo-landing__hero {
        padding: 48px 0 40px;
    }

    .repo-landing__title {
        font-size: 36px;
    }

    .repo-landing__hero-actions {
        flex-direction: column;
        width: 100%;
    }

    .repo-landing__cta-primary,
    .repo-landing__cta-secondary {
        width: 100%;
        text-align: center;
    }

    .repo-landing__footer {
        flex-direction: column;
        gap: 12px;
        text-align: center;
    }

    .repo-landing__code-block {
        flex-wrap: wrap;
    }

    .repo-landing__code-block code {
        width: 100%;
    }
}

/* Back to repos button (hosted mode sidebar) */
.back-to-repos {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    font-size: 12px;
    font-family: inherit;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--surface-color);
    color: var(--text-secondary);
    cursor: pointer;
    transition: color 150ms ease, border-color 150ms ease;
}

.back-to-repos:hover {
    color: var(--text-color);
    border-color: var(--text-secondary);
}

/* ── Git Lifecycle View ── */

.staging-view {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 10px;
    overflow: hidden;
    flex: 1;
    min-height: 0;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.015), transparent 24%),
        var(--bg-color);
}

.staging-zones {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    align-items: stretch;
    gap: 8px;
    flex: 1;
    min-height: 0;
}

/* ── Zone card ── */

.staging-zone {
    position: relative;
    display: flex;
    flex-direction: column;
    min-width: 0;
    min-height: 0;
    border: 1px solid var(--border-color);
    border-radius: 10px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.025), transparent 20%),
        var(--surface-color);
    overflow: hidden;
    box-shadow: 0 6px 16px rgba(15, 23, 42, 0.05);
}

.staging-zone--working {
    border-top: 3px solid var(--warning-color);
}

.staging-zone--staging {
    border-top: 3px solid var(--success-color);
}

.staging-zone--repo {
    border-top: 3px solid var(--node-color);
}

.staging-zone--local,
.staging-zone--repo {
    border-top: 3px solid var(--node-color);
}

.staging-zone--upstream {
    border-top: 3px solid var(--branch-node-color);
}

.staging-zone:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 22px;
    right: -7px;
    width: 12px;
    height: 12px;
    border-top: 2px solid rgba(148, 163, 184, 0.55);
    border-right: 2px solid rgba(148, 163, 184, 0.55);
    transform: rotate(45deg);
    pointer-events: none;
    z-index: 2;
}

.staging-zone-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    border-bottom: 1px solid var(--border-color);
}

.staging-zone-header-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
    flex: 1;
}

.staging-zone-title-row {
    display: flex;
    align-items: center;
    gap: 6px;
    min-width: 0;
    overflow: visible;
}

.staging-zone-icon {
    display: inline-flex;
    flex-shrink: 0;
}

.staging-zone-icon--warning { color: var(--warning-color); }
.staging-zone-icon--success { color: var(--success-color); }
.staging-zone-icon--info    { color: var(--node-color); }
.staging-zone-icon--upstream { color: var(--branch-node-color); }

.staging-zone-label {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-color);
    font-family: 'JetBrains Mono', 'Courier New', monospace;
}

.staging-zone-meta {
    font-size: 11px;
    color: var(--text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.staging-help {
    position: relative;
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
    overflow: visible;
}

.staging-help-button {
    width: 17px;
    height: 17px;
    border: 1px solid color-mix(in srgb, var(--border-color) 82%, transparent);
    border-radius: 999px;
    background: color-mix(in srgb, var(--surface-color) 90%, transparent);
    color: var(--text-secondary);
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 11px;
    font-weight: 700;
    line-height: 1;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
    transition: color 0.16s ease, border-color 0.16s ease, background-color 0.16s ease, transform 0.16s ease;
}

.staging-help-button:hover,
.staging-help-button:focus-visible {
    color: var(--text-color);
    border-color: color-mix(in srgb, var(--branch-node-color) 48%, var(--border-color));
    background: color-mix(in srgb, var(--surface-color) 76%, var(--branch-node-color));
    transform: translateY(-1px);
    outline: none;
}

.staging-help-tooltip {
    position: absolute;
    top: calc(100% + 10px);
    left: -4px;
    z-index: 6;
    width: 220px;
    padding: 10px 11px;
    border: 1px solid color-mix(in srgb, var(--branch-node-color) 20%, var(--border-color));
    border-radius: 10px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent 48%),
        color-mix(in srgb, var(--surface-color) 95%, black 5%);
    color: var(--text-color);
    font-size: 11px;
    line-height: 1.5;
    font-family: inherit;
    letter-spacing: 0;
    opacity: 0;
    pointer-events: none;
    box-shadow: 0 14px 30px rgba(15, 23, 42, 0.18);
    transform: translateY(-4px);
    transition: opacity 0.16s ease, transform 0.16s ease;
}

.staging-help-tooltip::before {
    content: "";
    position: absolute;
    top: -5px;
    left: 12px;
    width: 9px;
    height: 9px;
    border-top: 1px solid color-mix(in srgb, var(--branch-node-color) 20%, var(--border-color));
    border-left: 1px solid color-mix(in srgb, var(--branch-node-color) 20%, var(--border-color));
    background: color-mix(in srgb, var(--surface-color) 95%, black 5%);
    transform: rotate(45deg);
}

.staging-help:hover .staging-help-tooltip,
.staging-help-button:focus-visible + .staging-help-tooltip {
    opacity: 1;
    transform: translateY(0);
}

.staging-zone-badge {
    font-size: 11px;
    font-weight: 700;
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    min-width: 18px;
    text-align: center;
    padding: 1px 6px;
    border-radius: 10px;
    flex-shrink: 0;
}

.staging-zone-badge--warning {
    background: rgba(154, 103, 0, 0.15);
    color: var(--warning-color);
}

.staging-zone-badge--success {
    background: rgba(26, 127, 55, 0.15);
    color: var(--success-color);
}

.staging-zone-badge--info {
    background: rgba(14, 165, 233, 0.12);
    color: var(--node-color);
}

.staging-zone-badge--upstream {
    background: color-mix(in srgb, var(--branch-node-color) 14%, transparent);
    color: var(--branch-node-color);
}

@media (prefers-color-scheme: dark) {
    .staging-zone-badge--warning {
        background: rgba(210, 153, 34, 0.15);
    }
    .staging-zone-badge--success {
        background: rgba(63, 185, 80, 0.15);
    }
    .staging-zone-badge--info {
        background: rgba(88, 166, 255, 0.12);
    }
    .staging-zone-badge--upstream {
        background: color-mix(in srgb, var(--branch-node-color) 16%, transparent);
    }
}

.staging-zone-body {
    flex: 1;
    padding: 6px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-height: 240px;
    overflow-y: auto;
    overscroll-behavior: contain;
    scrollbar-gutter: stable;
}

.staging-zone-empty {
    color: var(--text-secondary);
    font-size: 12px;
    font-style: italic;
    text-align: center;
    margin: auto 0;
    padding: 14px 8px;
    opacity: 0.72;
    letter-spacing: 0.01em;
}

/* ── File card ── */

.staging-file-card {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 7px;
    border: 1px solid transparent;
    border-radius: 7px;
    background: rgba(255, 255, 255, 0.02);
    transition: background-color 0.15s ease, border-color 0.15s ease, transform 0.15s ease;
}

.staging-file-card--interactive {
    cursor: pointer;
}

.staging-file-card:hover {
    background: rgba(208, 215, 222, 0.32);
    border-color: rgba(148, 163, 184, 0.25);
    transform: translateX(2px);
}

@media (prefers-color-scheme: dark) {
    .staging-file-card:hover {
        background: rgba(48, 54, 61, 0.5);
    }
}

.staging-file-code {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-weight: 600;
    font-size: 11px;
    width: 18px;
    height: 18px;
    line-height: 18px;
    text-align: center;
    flex-shrink: 0;
    border-radius: 5px;
    background: rgba(128, 128, 128, 0.08);
    color: var(--text-secondary);
}

.staging-file-code--modified { color: var(--warning-color); }
.staging-file-code--added    { color: var(--success-color); }
.staging-file-code--deleted  { color: var(--danger-color); }
.staging-file-code--untracked { color: var(--text-secondary); opacity: 0.7; }

.staging-file-hash {
    font-size: 11px;
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    color: var(--text-secondary);
    opacity: 0.5;
    flex-shrink: 0;
}

.staging-file-name {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-width: 0;
    overflow: hidden;
}

.staging-file-base {
    font-size: 12px;
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    color: var(--text-color);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.staging-file-dir {
    font-size: 11px;
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    color: var(--text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    opacity: 0.5;
}

.staging-file-action {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-left: auto;
    padding: 4px 7px;
    border: 1px solid color-mix(in srgb, var(--border-color) 80%, transparent);
    border-radius: 999px;
    background: color-mix(in srgb, var(--surface-color) 90%, transparent);
    color: var(--text-secondary);
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 11px;
    line-height: 1;
    cursor: pointer;
    flex-shrink: 0;
    transition: color 0.15s ease, border-color 0.15s ease, background-color 0.15s ease;
}

.staging-file-action:hover,
.staging-file-action:focus-visible,
.staging-file-card:hover .staging-file-action {
    color: var(--text-color);
    border-color: color-mix(in srgb, var(--node-color) 40%, var(--border-color));
    background: color-mix(in srgb, var(--surface-color) 76%, var(--node-color));
    outline: none;
}

.staging-summary-card {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 10px 11px;
    margin: auto 0;
    border: 1px solid rgba(148, 163, 184, 0.2);
    border-radius: 9px;
    background: rgba(255, 255, 255, 0.025);
}

.staging-summary-card--ahead {
    border-color: rgba(14, 165, 233, 0.28);
}

.staging-summary-card--behind {
    border-color: rgba(245, 158, 11, 0.32);
}

.staging-summary-card--diverged {
    border-color: rgba(239, 68, 68, 0.28);
}

.staging-summary-title {
    font-size: 12px;
    font-weight: 700;
    color: var(--text-color);
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    letter-spacing: 0.02em;
}

.staging-summary-meta {
    font-size: 11px;
    color: var(--text-secondary);
    font-family: 'JetBrains Mono', 'Courier New', monospace;
}

.staging-diff-overlay {
    position: absolute;
    inset: 10px;
    z-index: 8;
    display: none;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    overflow: hidden;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.02), transparent 20%),
        var(--surface-color);
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.18);
}

.staging-diff-overlay .diff-content-viewer {
    background: var(--surface-color);
}

.staging-diff-open-explorer {
    margin-left: auto;
    padding: 5px 9px;
    border: 1px solid color-mix(in srgb, var(--border-color) 80%, transparent);
    border-radius: 999px;
    background: color-mix(in srgb, var(--surface-color) 90%, transparent);
    color: var(--text-secondary);
    font-size: 11px;
    line-height: 1;
    cursor: pointer;
    transition: color 0.15s ease, border-color 0.15s ease, background-color 0.15s ease;
}

.staging-diff-open-explorer:hover,
.staging-diff-open-explorer:focus-visible {
    color: var(--text-color);
    border-color: color-mix(in srgb, var(--node-color) 42%, var(--border-color));
    background: color-mix(in srgb, var(--surface-color) 78%, var(--node-color));
    outline: none;
}

/* ── Animations ── */

@keyframes staging-slide-down {
    from {
        opacity: 0;
        transform: translateX(-18px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes staging-slide-up {
    from {
        opacity: 0;
        transform: translateX(18px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes staging-fade-in {
    from {
        opacity: 0;
        transform: scale(0.95);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

@keyframes staging-committed-fade {
    from { opacity: 0.6; }
    to { opacity: 0.15; }
}

.staging-anim-slide-down {
    animation: staging-slide-down 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.staging-anim-slide-up {
    animation: staging-slide-up 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.staging-anim-fade-in {
    animation: staging-fade-in 0.25s ease-out;
}

.staging-anim-committed-fade {
    animation: staging-committed-fade 3s ease-out forwards;
}

@container (max-width: 980px) {
    .staging-view {
        overflow-y: auto;
    }

    .staging-zones {
        grid-template-columns: 1fr;
        flex: none;
    }

    .staging-zone-body {
        min-height: 0;
    }

    .staging-zone:not(:last-child)::after {
        top: auto;
        bottom: -7px;
        right: 50%;
        transform: translateX(50%) rotate(135deg);
    }

    .staging-help-tooltip {
        left: 0;
        width: min(220px, calc(100vw - 56px));
        transform: translateY(-4px);
    }

    .staging-help:hover .staging-help-tooltip,
    .staging-help-button:focus-visible + .staging-help-tooltip {
        transform: translateY(0);
    }

    .staging-diff-overlay {
        inset: 8px;
    }
}

/* ── Error Boundary Components ────────────────────────────────────────── */

/* Connection Banner */
.connection-banner {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 8px 16px;
    font-size: 13px;
    font-weight: 500;
    transition: background 300ms ease, color 300ms ease;
}

.connection-banner--warning {
    background: var(--warning-color);
    color: #fff;
}

.connection-banner--error {
    background: var(--danger-color);
    color: #fff;
}

.connection-banner--success {
    background: var(--success-color);
    color: #fff;
}

.connection-banner-text {
    flex: 1;
    text-align: center;
}

.connection-banner-dismiss {
    background: none;
    border: none;
    color: inherit;
    font-size: 18px;
    cursor: pointer;
    padding: 0 4px;
    opacity: 0.8;
    line-height: 1;
}

.connection-banner-dismiss:hover {
    opacity: 1;
}

/* Inline Error */
.inline-error {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 24px 16px;
    text-align: center;
    color: var(--text-secondary);
}

.inline-error-icon {
    font-size: 24px;
    color: var(--warning-color);
}

.inline-error-message {
    font-size: 13px;
}

.inline-error-retry {
    padding: 4px 14px;
    font-size: 12px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--surface-color);
    color: var(--text-color);
    cursor: pointer;
    transition: background 150ms ease;
}

.inline-error-retry:hover {
    background: var(--bg-color);
}

/* Repository Unavailable Overlay */
.repo-unavailable-overlay {
    position: fixed;
    inset: 0;
    z-index: 10001;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(2px);
}

.repo-unavailable-card {
    background: var(--surface-elevated);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 32px 40px;
    max-width: 400px;
    text-align: center;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
}

.repo-unavailable-icon {
    font-size: 40px;
    color: var(--warning-color);
    margin-bottom: 12px;
}

.repo-unavailable-title {
    font-size: 18px;
    font-weight: 600;
    color: var(--text-color);
    margin: 0 0 8px;
}

.repo-unavailable-desc {
    font-size: 13px;
    color: var(--text-secondary);
    line-height: 1.5;
    margin: 0 0 20px;
}

.repo-unavailable-retry {
    padding: 8px 20px;
    font-size: 13px;
    font-weight: 500;
    border: none;
    border-radius: 6px;
    background: var(--accent-color);
    color: #fff;
    cursor: pointer;
    transition: opacity 150ms ease;
}

.repo-unavailable-retry:hover {
    opacity: 0.9;
}

.repo-unavailable-retry:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.repo-unavailable-back {
    display: block;
    margin-top: 12px;
    font-size: 12px;
    color: var(--accent-color);
    text-decoration: none;
}

.repo-unavailable-back:hover {
    text-decoration: underline;
}

/* ── Analytics View ── */

.analytics-view {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 14px;
    height: 100%;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: var(--border-color) transparent;
}

/* ── Stat Cards ── */

.analytics-summary {
    display: flex;
    gap: 6px;
}

.analytics-stat {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 10px 6px 8px;
    background: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    position: relative;
    overflow: hidden;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.analytics-stat::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--node-color);
    opacity: 0.5;
    transition: opacity 0.2s ease;
}

.analytics-stat:hover {
    border-color: color-mix(in srgb, var(--node-color) 40%, var(--border-color));
    box-shadow: 0 2px 8px color-mix(in srgb, var(--node-color) 8%, transparent);
}

.analytics-stat:hover::before {
    opacity: 1;
}

.analytics-stat-value {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 15px;
    font-weight: 600;
    color: var(--text-color);
    line-height: 1.2;
    letter-spacing: -0.02em;
}

.analytics-stat-label {
    font-size: 11px;
    font-weight: 500;
    color: var(--text-secondary);
    margin-top: 3px;
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

/* ── Period Selector ── */

.analytics-period-selector {
    display: flex;
    flex-wrap: wrap;
    gap: 2px;
    background: var(--border-color);
    border-radius: 6px;
    padding: 2px;
}

.analytics-period-custom {
    display: flex;
    gap: 4px;
    margin-left: auto;
    align-items: center;
}

.analytics-period-input {
    min-width: 132px;
    padding: 4px 6px;
    font-size: 12px;
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    color: var(--text-color);
    background: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: 4px;
}

.analytics-period-custom-status {
    font-size: 11px;
    color: var(--text-secondary);
    margin-left: 4px;
    white-space: nowrap;
}

.analytics-period-btn {
    flex: 1;
    padding: 5px 8px;
    font-size: 12px;
    font-weight: 500;
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    border: none;
    border-radius: 4px;
    background: transparent;
    color: var(--text-secondary);
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

.analytics-period-btn:hover {
    color: var(--text-color);
    background: color-mix(in srgb, var(--surface-color) 60%, transparent);
}

.analytics-period-btn.is-active {
    background: var(--node-color);
    color: #fff;
    box-shadow: 0 1px 3px color-mix(in srgb, var(--node-color) 30%, transparent);
}

/* ── Chart Containers ── */

.analytics-chart-container {
    position: relative;
    min-height: 200px;
    background: var(--surface-elevated);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    overflow: hidden;
}

.analytics-chart-canvas {
    display: block;
    width: 100%;
    height: 200px;
}

/* ── Tooltip ── */

.analytics-tooltip {
    display: none;
    position: absolute;
    padding: 5px 10px;
    font-size: 12px;
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    color: var(--text-color);
    background: var(--surface-elevated);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1), 0 1px 3px rgba(0, 0, 0, 0.06);
    pointer-events: none;
    white-space: nowrap;
    z-index: 10;
    backdrop-filter: blur(8px);
}

/* ── Empty State ── */

.analytics-empty {
    display: none;
    padding: 40px 20px;
    text-align: center;
    font-size: 13px;
    color: var(--text-secondary);
    line-height: 1.6;
}

.analytics-loading {
    display: none;
    padding: 32px 20px;
    text-align: center;
    font-size: 12px;
    font-weight: 500;
    color: var(--text-secondary);
    background: color-mix(in srgb, var(--node-color) 6%, var(--surface-color));
    border: 1px dashed color-mix(in srgb, var(--node-color) 25%, var(--border-color));
    border-radius: 8px;
}

/* ── Actionable Summary ── */

.analytics-signal-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}

.analytics-signal-card {
    padding: 10px;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    background: var(--surface-elevated);
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.analytics-signal-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.analytics-signal-title {
    font-size: 12px;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.analytics-signal-status {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 11px;
    padding: 2px 6px;
    border-radius: 999px;
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
}

.analytics-signal-status.is-risk {
    color: #fff;
    background: #b91c1c;
    border-color: #b91c1c;
}

.analytics-signal-status.is-watch {
    color: #7c2d12;
    background: #fed7aa;
    border-color: #fdba74;
}

.analytics-signal-status.is-ok {
    color: #065f46;
    background: #bbf7d0;
    border-color: #86efac;
}

.analytics-signal-metric {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 18px;
    font-weight: 600;
    color: var(--text-color);
}

.analytics-signal-delta {
    font-size: 12px;
    color: var(--text-secondary);
}

.analytics-signal-recommendation {
    margin: 0;
    font-size: 12px;
    line-height: 1.4;
    color: var(--text-secondary);
}

.analytics-delta-strip {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 6px;
}

.analytics-delta-chip {
    display: flex;
    flex-direction: column;
    gap: 2px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--surface-color);
    padding: 6px 8px;
}

.analytics-delta-chip-label {
    font-size: 11px;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.analytics-delta-chip-value {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 13px;
    font-weight: 600;
    color: var(--text-color);
}

.analytics-delta-chip-value.is-up {
    color: #b91c1c;
}

.analytics-delta-chip-value.is-down {
    color: #047857;
}

/* ── Hotspots ── */

.analytics-hotspot-coverage {
    font-size: 12px;
    color: var(--text-secondary);
    padding: 8px 10px;
    border: 1px dashed var(--border-color);
    border-radius: 6px;
    background: color-mix(in srgb, var(--surface-color) 85%, var(--bg-color));
}

.analytics-hotspot-table {
    width: 100%;
    border-collapse: collapse;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    overflow: hidden;
    font-size: 12px;
    background: var(--surface-elevated);
}

.analytics-hotspot-table th,
.analytics-hotspot-table td {
    padding: 8px 10px;
    border-bottom: 1px solid var(--border-color);
    text-align: left;
    vertical-align: top;
}

.analytics-hotspot-table th {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-secondary);
    background: var(--surface-color);
}

.analytics-hotspot-path {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    color: var(--text-color);
}

.analytics-hotspot-risk {
    display: inline-flex;
    min-width: 28px;
    justify-content: center;
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 12px;
    border-radius: 999px;
    padding: 2px 6px;
}

.analytics-hotspot-risk.is-risk {
    color: #fff;
    background: #b91c1c;
}

.analytics-hotspot-risk.is-watch {
    color: #7c2d12;
    background: #fed7aa;
}

.analytics-hotspot-risk.is-ok {
    color: #065f46;
    background: #bbf7d0;
}

.analytics-hotspot-rec {
    color: var(--text-secondary);
    max-width: 320px;
}

.analytics-hotspot-empty {
    color: var(--text-secondary);
    text-align: center;
    font-style: italic;
}

/* ── Sections ── */

.analytics-section {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 0 0 16px;
    border-top: 1px solid var(--border-color);
    padding-top: 14px;
}

.analytics-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.analytics-section-heading {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
}

.analytics-section-body {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.analytics-section-toggle {
    border: 1px solid color-mix(in srgb, var(--border-color) 88%, transparent);
    border-radius: 999px;
    background: color-mix(in srgb, var(--surface-color) 92%, transparent);
    color: var(--text-secondary);
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 11px;
    font-weight: 700;
    line-height: 1;
    padding: 7px 10px;
    cursor: pointer;
    transition: color 0.16s ease, border-color 0.16s ease, background-color 0.16s ease, transform 0.16s ease;
}

.analytics-section-toggle:hover,
.analytics-section-toggle:focus-visible {
    color: var(--text-color);
    border-color: color-mix(in srgb, var(--node-color) 35%, var(--border-color));
    background: color-mix(in srgb, var(--surface-color) 76%, var(--node-color));
    transform: translateY(-1px);
    outline: none;
}

.analytics-section-title {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-secondary);
    margin: 0 0 2px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.analytics-section-title::before {
    content: '';
    display: inline-block;
    width: 3px;
    height: 12px;
    border-radius: 2px;
    background: var(--node-color);
    opacity: 0.6;
}

.analytics-help {
    position: relative;
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
    overflow: visible;
}

.analytics-help-button {
    width: 17px;
    height: 17px;
    border: 1px solid color-mix(in srgb, var(--border-color) 82%, transparent);
    border-radius: 999px;
    background: color-mix(in srgb, var(--surface-color) 90%, transparent);
    color: var(--text-secondary);
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 11px;
    font-weight: 700;
    line-height: 1;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
    transition: color 0.16s ease, border-color 0.16s ease, background-color 0.16s ease, transform 0.16s ease;
}

.analytics-help-button:hover,
.analytics-help-button:focus-visible {
    color: var(--text-color);
    border-color: color-mix(in srgb, var(--node-color) 48%, var(--border-color));
    background: color-mix(in srgb, var(--surface-color) 76%, var(--node-color));
    transform: translateY(-1px);
    outline: none;
}

.analytics-help-tooltip {
    position: absolute;
    top: calc(100% + 10px);
    left: -4px;
    z-index: 6;
    width: 240px;
    padding: 10px 11px;
    border: 1px solid color-mix(in srgb, var(--node-color) 20%, var(--border-color));
    border-radius: 10px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent 48%),
        color-mix(in srgb, var(--surface-color) 95%, black 5%);
    color: var(--text-color);
    font-size: 11px;
    line-height: 1.5;
    font-family: inherit;
    letter-spacing: 0;
    opacity: 0;
    pointer-events: none;
    box-shadow: 0 14px 30px rgba(15, 23, 42, 0.18);
    transform: translateY(-4px);
    transition: opacity 0.16s ease, transform 0.16s ease;
}

.analytics-help-tooltip::before {
    content: "";
    position: absolute;
    top: -5px;
    left: 12px;
    width: 9px;
    height: 9px;
    border-top: 1px solid color-mix(in srgb, var(--node-color) 20%, var(--border-color));
    border-left: 1px solid color-mix(in srgb, var(--node-color) 20%, var(--border-color));
    background: color-mix(in srgb, var(--surface-color) 95%, black 5%);
    transform: rotate(45deg);
}

.analytics-help:hover .analytics-help-tooltip,
.analytics-help-button:focus-visible + .analytics-help-tooltip {
    opacity: 1;
    transform: translateY(0);
}

@media (max-width: 1100px) {
    .analytics-signal-grid {
        grid-template-columns: 1fr;
    }

    .analytics-delta-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .analytics-hotspot-table {
        font-size: 11px;
    }

    .analytics-section-header {
        align-items: flex-start;
        flex-direction: column;
    }
}

/* ── Diff Stats Loading ── */

.analytics-diff-stats-msg {
    padding: 12px 14px;
    font-size: 11px;
    font-weight: 500;
    color: var(--text-secondary);
    background: color-mix(in srgb, var(--node-color) 6%, var(--surface-color));
    border: 1px dashed color-mix(in srgb, var(--node-color) 25%, var(--border-color));
    border-radius: 6px;
    text-align: center;
    letter-spacing: 0.01em;
}

/* ── Merge Preview View ── */

.merge-preview-view {
    display: flex;
    flex-direction: column;
    flex: 1;
    overflow: hidden;
    font-size: 13px;
}

.merge-preview-branch-selectors {
    display: flex;
    align-items: flex-end;
    gap: 6px;
    padding: 12px 14px;
    border-bottom: 1px solid var(--border-color);
}

.merge-preview-select-wrapper {
    display: flex;
    flex-direction: column;
    gap: 3px;
    flex: 1;
    min-width: 0;
}

.merge-preview-select-label {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-secondary);
}

.merge-preview-select {
    width: 100%;
    padding: 5px 8px;
    font-size: 12px;
    font-family: inherit;
    background: var(--surface-color);
    color: var(--text-color);
    border: 1px solid var(--border-color);
    border-radius: 5px;
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath d='M3 4l2 2 2-2' fill='none' stroke='%2357606a' stroke-width='1.2'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 6px center;
    padding-right: 22px;
    text-overflow: ellipsis;
}

.merge-preview-select:focus {
    outline: 2px solid var(--node-color);
    outline-offset: -1px;
}

.merge-preview-swap-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    flex-shrink: 0;
    background: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: 5px;
    cursor: pointer;
    color: var(--text-secondary);
    transition: color 150ms ease, border-color 150ms ease;
}

.merge-preview-swap-btn:hover {
    color: var(--text-color);
    border-color: var(--node-color);
}

.merge-preview-stats {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 14px;
    font-size: 12px;
    font-weight: 500;
    border-bottom: 1px solid var(--border-color);
    color: var(--text-secondary);
}

.merge-preview-stat--conflict {
    color: var(--danger-color);
}

.merge-preview-stat--clean {
    color: var(--success-color);
}

.merge-preview-file-list {
    flex: 1;
    overflow-y: auto;
}

.merge-preview-file-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 14px;
    border-bottom: 1px solid color-mix(in srgb, var(--border-color) 40%, transparent);
    cursor: pointer;
    transition: background-color 0.15s ease;
}

.merge-preview-file-item:hover {
    background: color-mix(in srgb, var(--node-color) 8%, transparent);
}

.merge-preview-file-item.is-selected {
    background: color-mix(in srgb, var(--node-color) 15%, transparent);
    border-left: 2px solid var(--node-color);
}

.merge-preview-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 18px;
    padding: 0 4px;
    font-size: 11px;
    font-weight: 700;
    border-radius: 3px;
    flex-shrink: 0;
    font-family: 'JetBrains Mono', monospace;
}

.merge-status--clean {
    background: rgba(26, 127, 55, 0.15);
    color: var(--success-color);
}

.merge-status--conflict {
    background: rgba(209, 36, 47, 0.15);
    color: var(--danger-color);
}

.merge-status--delete-modify {
    background: rgba(217, 119, 6, 0.15);
    color: var(--warning-color);
}

@media (prefers-color-scheme: dark) {
    .merge-status--clean {
        background: rgba(63, 185, 80, 0.15);
    }
    .merge-status--conflict {
        background: rgba(248, 81, 73, 0.15);
    }
    .merge-status--delete-modify {
        background: rgba(210, 153, 34, 0.15);
    }
}

.merge-preview-file-path {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 12px;
    font-family: 'JetBrains Mono', monospace;
}

.merge-preview-file-dir {
    color: var(--text-secondary);
}

.merge-preview-sides {
    display: flex;
    gap: 3px;
    flex-shrink: 0;
}

.merge-preview-side-indicator {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    font-size: 11px;
    font-weight: 600;
    border-radius: 3px;
    background: color-mix(in srgb, var(--border-color) 50%, transparent);
    color: var(--text-secondary);
}

.merge-preview-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 40px 20px;
    color: var(--text-secondary);
    text-align: center;
    flex: 1;
}

.merge-preview-empty p {
    font-size: 12px;
    margin: 0;
}

.merge-preview-message {
    padding: 16px 14px;
    font-size: 12px;
    color: var(--text-secondary);
    text-align: center;
}

.merge-preview-loading {
    padding: 24px 14px;
    font-size: 12px;
    color: var(--text-secondary);
    text-align: center;
}

.merge-preview-error {
    padding: 12px 14px;
    margin: 8px 14px;
    font-size: 12px;
    color: var(--danger-color);
    background: rgba(209, 36, 47, 0.08);
    border: 1px solid rgba(209, 36, 47, 0.2);
    border-radius: 6px;
}

/* Three-way diff viewer */
.merge-diff-viewer {
    display: flex;
    flex-direction: column;
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    overflow-y: auto;
    flex: 1;
}

.merge-diff-regions {
    display: flex;
    flex-direction: column;
}

.merge-diff-line {
    display: flex;
    padding: 0 12px;
    line-height: 20px;
    min-height: 20px;
    white-space: pre;
}

.merge-diff-line .line-content {
    flex: 1;
    overflow-x: auto;
}

.merge-diff-line--base {
    text-decoration: line-through;
    opacity: 0.6;
}

/* Region headers */
.merge-region-header {
    padding: 2px 12px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    line-height: 18px;
}

.merge-region-header--ours {
    color: #1a7f37;
    background: rgba(26, 127, 55, 0.08);
}

.merge-region-header--theirs {
    color: #0550ae;
    background: rgba(5, 80, 174, 0.08);
}

.merge-region-header--conflict {
    color: #cf222e;
    background: rgba(207, 34, 46, 0.08);
}

/* Theirs addition lines — blue tint to differentiate from ours green */
.diff-line-theirs-add {
    background: rgba(5, 80, 174, 0.08);
    color: var(--text-color);
}

/* Conflict region wrapper */
.merge-conflict-region {
    border-left: 3px solid #cf222e;
    margin: 2px 0;
}

/* Sub-headers inside conflict regions */
.merge-conflict-section-header {
    padding: 1px 12px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    line-height: 16px;
    opacity: 0.7;
}

.merge-conflict-section-header--base {
    color: var(--text-secondary);
    background: color-mix(in srgb, var(--border-color) 30%, transparent);
}

.merge-conflict-section-header--ours {
    color: #1a7f37;
    background: rgba(26, 127, 55, 0.05);
}

.merge-conflict-section-header--theirs {
    color: #0550ae;
    background: rgba(5, 80, 174, 0.05);
}

/* Merge diff stats bar */
.merge-diff-stats {
    display: flex;
    gap: 12px;
    padding: 6px 12px;
    font-size: 11px;
    border-bottom: 1px solid var(--border-color);
}

.merge-diff-stat {
    font-weight: 500;
}

.merge-diff-stat--ours {
    color: #1a7f37;
}

.merge-diff-stat--theirs {
    color: #0550ae;
}

.merge-diff-stat--conflict {
    color: #cf222e;
}

/* Dark mode overrides */
@media (prefers-color-scheme: dark) {
    .merge-region-header--ours {
        color: #3fb950;
        background: rgba(63, 185, 80, 0.1);
    }

    .merge-region-header--theirs {
        color: #58a6ff;
        background: rgba(88, 166, 255, 0.1);
    }

    .merge-region-header--conflict {
        color: #f85149;
        background: rgba(248, 81, 73, 0.1);
    }

    .diff-line-theirs-add {
        background: rgba(88, 166, 255, 0.1);
    }

    .merge-conflict-region {
        border-left-color: #f85149;
    }

    .merge-conflict-section-header--ours {
        color: #3fb950;
        background: rgba(63, 185, 80, 0.06);
    }

    .merge-conflict-section-header--theirs {
        color: #58a6ff;
        background: rgba(88, 166, 255, 0.06);
    }

    .merge-diff-stat--ours {
        color: #3fb950;
    }

    .merge-diff-stat--theirs {
        color: #58a6ff;
    }

    .merge-diff-stat--conflict {
        color: #f85149;
    }
}

/* ═══════════════════════════════════════════════════════════════════════════
 * Breadcrumb Bar
 * ═══════════════════════════════════════════════════════════════════════════ */

.graph-breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    height: 24px;
    padding: 0 10px;
    background: var(--breadcrumb-bg);
    border-bottom: 1px solid var(--border-color);
    font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, monospace;
    font-size: 11px;
    color: var(--text-secondary);
    flex-shrink: 0;
    overflow: hidden;
    white-space: nowrap;
}

.graph-breadcrumb__branch {
    color: var(--node-color);
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
}

.graph-breadcrumb__branch:hover {
    text-decoration: underline;
}

.graph-breadcrumb__sep {
    color: var(--border-color);
    user-select: none;
}

.graph-breadcrumb__hash {
    color: var(--text-color);
    font-weight: 500;
}

.graph-breadcrumb__message {
    color: var(--text-secondary);
    overflow: hidden;
    text-overflow: ellipsis;
    flex: 1;
    min-width: 0;
}

.graph-breadcrumb__position {
    margin-left: auto;
    color: var(--text-secondary);
    font-variant-numeric: tabular-nums;
    flex-shrink: 0;
}

.graph-breadcrumb--empty {
    color: var(--text-secondary);
    font-style: italic;
}

/* ═══════════════════════════════════════════════════════════════════════════
 * Minimap
 * ═══════════════════════════════════════════════════════════════════════════ */

.graph-minimap {
    position: absolute;
    bottom: 16px;
    right: 16px;
    width: 200px;
    height: 140px;
    background: var(--minimap-bg);
    border: 1px solid var(--overlay-border);
    border-radius: 8px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);
    cursor: crosshair;
    z-index: 50;
    overflow: hidden;
    pointer-events: auto;
}

.graph-minimap canvas {
    width: 100%;
    height: 100%;
    display: block;
    flex: none;
    min-height: auto;
    background: transparent;
}

/* ═══════════════════════════════════════════════════════════════════════════
 * Settings Overlay
 * ═══════════════════════════════════════════════════════════════════════════ */

.graph-settings-trigger {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--surface-color);
    color: var(--text-secondary);
    cursor: pointer;
    font-size: 14px;
    line-height: 1;
    transition: all 0.15s ease;
    flex-shrink: 0;
    padding: 0;
}

.graph-settings-trigger:hover {
    background: var(--surface-recessed);
    color: var(--text-color);
}

.graph-settings-trigger.is-active {
    background: var(--node-color);
    color: #fff;
    border-color: var(--node-color);
}

.graph-settings-overlay {
    position: absolute;
    width: min(360px, calc(100% - 16px));
    max-width: calc(100% - 16px);
    max-height: min(540px, calc(100% - 16px));
    overflow-y: auto;
    background: var(--overlay-bg);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid var(--overlay-border);
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.18);
    z-index: 100;
    padding: 14px;
    font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, monospace;
    font-size: 11px;
    color: var(--text-color);
    display: none;
}

.graph-settings-overlay.is-visible {
    display: block;
    animation: graph-settings-pop 0.18s ease-out;
}

.graph-settings-overlay__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border-color);
}

.graph-settings-overlay__title-wrap {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
}

.graph-settings-overlay__title {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: var(--text-color);
}

.graph-settings-overlay__mode-pill {
    align-self: flex-start;
    padding: 3px 8px;
    border-radius: 999px;
    border: 1px solid rgba(14, 165, 233, 0.18);
    background: rgba(14, 165, 233, 0.1);
    color: var(--text-secondary);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.graph-settings-overlay__action {
    border: 1px solid var(--border-color);
    border-radius: 999px;
    background: var(--surface-color);
    color: var(--text-color);
    cursor: pointer;
    font-family: inherit;
    font-size: 11px;
    font-weight: 600;
    line-height: 1;
    padding: 6px 10px;
    transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.graph-settings-overlay__action:hover {
    background: var(--surface-recessed);
    border-color: var(--node-color);
}

.graph-settings-overlay__action--subtle {
    padding: 4px 8px;
    border-radius: 8px;
    font-size: 11px;
    color: var(--text-secondary);
}

.graph-settings-overlay__branch-tools {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 8px;
}

.graph-settings-overlay__branch-search {
    width: 100%;
    padding: 7px 9px;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    background: var(--surface-color);
    color: var(--text-color);
    font-family: inherit;
    font-size: 11px;
    outline: none;
}

.graph-settings-overlay__branch-search:focus {
    border-color: var(--node-color);
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.12);
}

.graph-settings-overlay__branch-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.graph-settings-overlay__section {
    margin-bottom: 14px;
}

.graph-settings-overlay__section:last-child {
    margin-bottom: 0;
}

.graph-settings-overlay__section-header {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-secondary);
    margin-bottom: 10px;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--border-color);
}

.graph-settings-overlay__row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
}

.graph-settings-overlay__row:last-child {
    margin-bottom: 0;
}

.graph-settings-overlay__label {
    flex-shrink: 0;
    width: 80px;
    color: var(--text-secondary);
    font-size: 11px;
}

.graph-settings-overlay__value {
    flex-shrink: 0;
    width: 40px;
    text-align: right;
    font-variant-numeric: tabular-nums;
    color: var(--text-color);
    font-size: 11px;
}

.graph-settings-overlay__reset {
    flex-shrink: 0;
    width: 18px;
    height: 18px;
    border: none;
    border-radius: 4px;
    background: transparent;
    color: var(--text-secondary);
    cursor: pointer;
    font-size: 12px;
    line-height: 1;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0.5;
    transition: opacity 0.15s;
}

.graph-settings-overlay__reset:hover {
    opacity: 1;
    background: var(--surface-recessed);
}

/* Custom range slider */
.graph-settings-overlay input[type="range"] {
    -webkit-appearance: none;
    appearance: none;
    flex: 1;
    height: 4px;
    background: var(--slider-track);
    border-radius: 2px;
    outline: none;
    cursor: pointer;
}

.graph-settings-overlay input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--slider-thumb);
    border: 2px solid var(--slider-thumb-border);
    cursor: pointer;
    transition: border-color 0.15s;
}

.graph-settings-overlay input[type="range"]::-webkit-slider-thumb:hover {
    border-color: var(--slider-fill);
}

.graph-settings-overlay input[type="range"]::-moz-range-thumb {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--slider-thumb);
    border: 2px solid var(--slider-thumb-border);
    cursor: pointer;
}

.graph-settings-overlay input[type="range"]::-moz-range-track {
    height: 4px;
    background: var(--slider-track);
    border-radius: 2px;
}

.graph-settings-overlay select {
    flex: 1;
    padding: 3px 6px;
    font-family: inherit;
    font-size: 11px;
    background: var(--surface-color);
    color: var(--text-color);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    outline: none;
    cursor: pointer;
}

.graph-settings-overlay select:focus {
    border-color: var(--node-color);
}

/* Branch checkbox list in scope section */
.graph-settings-overlay__branch-list {
    max-height: 164px;
    overflow-y: auto;
    padding: 4px 0;
    border-top: 1px solid rgba(127, 127, 127, 0.12);
}

.graph-settings-overlay__branch-item {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 5px 0;
    font-size: 11px;
    color: var(--text-color);
}

.graph-settings-overlay__branch-item input[type="checkbox"] {
    accent-color: var(--slider-fill);
}

.graph-settings-overlay__branch-meta {
    margin-left: auto;
    color: var(--text-secondary);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.graph-settings-overlay__branch-empty {
    padding: 10px 0 4px;
    color: var(--text-secondary);
    font-size: 11px;
}

@keyframes graph-settings-pop {
    from {
        opacity: 0;
        transform: translateY(-6px) scale(0.985);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@media (max-width: 900px) {
    .graph-settings-overlay {
        width: min(320px, calc(100% - 12px));
        max-width: calc(100% - 12px);
        padding: 12px;
    }

    .graph-settings-overlay__header {
        flex-direction: column;
        align-items: stretch;
    }

    .graph-settings-overlay__action {
        align-self: flex-start;
    }
}

/* ── Telemetry Overlay ───────────────────────────────────────────────── */
.telemetry-trigger {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    height: 26px;
    padding: 0 10px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--surface-color);
    color: var(--text-secondary);
    cursor: pointer;
    font: 600 11px/1 "JetBrains Mono", "SFMono-Regular", Menlo, Consolas, monospace;
    transition: all 0.15s ease;
    flex-shrink: 0;
}

.telemetry-trigger__icon {
    width: 12px;
    height: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: color-mix(in srgb, var(--node-color) 72%, var(--text-secondary) 28%);
}

.telemetry-trigger__icon svg {
    display: block;
}

.telemetry-trigger__label {
    line-height: 1;
}

.telemetry-trigger:hover {
    background: var(--surface-recessed);
    color: var(--text-color);
}

.telemetry-trigger:focus-visible {
    outline: 2px solid var(--node-color);
    outline-offset: 2px;
}

.telemetry-trigger.is-active {
    background: var(--node-color);
    color: #fff;
    border-color: var(--node-color);
}

.telemetry-trigger.is-active .telemetry-trigger__icon {
    color: #fff;
}

.telemetry-overlay {
    position: absolute;
    top: 44px;
    right: 8px;
    width: min(360px, calc(100vw - 16px));
    max-height: calc(100vh - 160px);
    overflow: hidden;
    background: var(--overlay-bg);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid var(--overlay-border);
    border-radius: 12px;
    box-shadow: 0 12px 34px rgba(0, 0, 0, 0.22);
    z-index: 105;
    display: none;
}

.telemetry-overlay.is-visible {
    display: flex;
    flex-direction: column;
    animation: telemetry-pop 120ms ease-out;
}

@keyframes telemetry-pop {
    from {
        opacity: 0;
        transform: translateY(-4px) scale(0.985);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.telemetry-overlay__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 10px 12px;
    border-bottom: 1px solid var(--border-color);
    color: var(--text-color);
    font: 600 11px/1.2 "JetBrains Mono", "SFMono-Regular", Menlo, Consolas, monospace;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.telemetry-overlay__close {
    appearance: none;
    border: 1px solid var(--border-color);
    background: transparent;
    color: var(--text-secondary);
    border-radius: 6px;
    font: 500 10px/1 "Geist", system-ui, sans-serif;
    padding: 4px 8px;
    cursor: pointer;
}

.telemetry-overlay__close:hover {
    color: var(--text-color);
    background: color-mix(in srgb, var(--surface-color) 72%, transparent);
}

.telemetry-overlay__body {
    overflow-y: auto;
    padding: 10px 12px 12px;
}

.telemetry-overlay__metrics {
    display: grid;
    grid-template-columns: 1fr;
    gap: 6px;
}

.telemetry-overlay__metric {
    display: grid;
    grid-template-columns: minmax(108px, 40%) 1fr;
    gap: 10px;
    align-items: start;
    padding: 6px 8px;
    border-radius: 8px;
    background: color-mix(in srgb, var(--surface-color) 68%, transparent);
}

.telemetry-overlay__metric-key {
    color: var(--text-secondary);
    font: 600 10px/1.25 "JetBrains Mono", "SFMono-Regular", Menlo, Consolas, monospace;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.telemetry-overlay__metric-value {
    color: var(--text-color);
    font: 500 11px/1.35 "JetBrains Mono", "SFMono-Regular", Menlo, Consolas, monospace;
    word-break: break-word;
}

.telemetry-overlay__metric-value.is-ok {
    color: var(--success-color);
}

.telemetry-overlay__metric-value.is-warn {
    color: var(--warning-color);
}

.telemetry-overlay__metric-value.is-error {
    color: var(--danger-color);
}

@media (max-width: 760px) {
    .telemetry-trigger {
        padding: 0 8px;
        font-size: 11px;
    }

    .telemetry-overlay {
        top: 40px;
        right: 6px;
        width: min(94vw, 360px);
        max-height: min(64vh, 540px);
    }
}

/* ── Cohesion + Smoothness pass (subtle, palette-preserving) ───────────── */

:root {
    --gv-radius-sm: 8px;
    --gv-radius-md: 10px;
    --gv-radius-lg: 12px;
    --gv-ease: 180ms cubic-bezier(0.2, 0.8, 0.2, 1);
    --gv-focus: 0 0 0 2px color-mix(in srgb, var(--node-color) 22%, transparent);
}

body {
    background:
        radial-gradient(900px 360px at 15% -15%, color-mix(in srgb, var(--node-color) 8%, transparent), transparent 70%),
        var(--bg-color);
}

#root {
    background: color-mix(in srgb, var(--surface-color) 94%, var(--bg-color));
}

.activity-bar,
.sidebar-panel,
.workbench-tabbar,
.canvas-toolbar,
.graph-breadcrumb {
    backdrop-filter: blur(4px);
}

.activity-bar-icon,
.workbench-tab,
.workbench-group-btn,
.sidebar-dock-btn,
.sidebar-panel-close,
.commit-search,
.commit-search-clear,
.repo-landing__cta-primary,
.repo-landing__cta-secondary,
.repo-landing__card,
.repo-landing__card-cta,
.repo-landing__input,
.repo-landing__add-btn,
.repo-landing__item,
.repo-landing__copy-btn,
.back-to-repos {
    transition:
        color var(--gv-ease),
        background-color var(--gv-ease),
        border-color var(--gv-ease),
        box-shadow var(--gv-ease),
        transform var(--gv-ease),
        opacity var(--gv-ease);
}

.workbench-tabbar {
    min-height: 40px;
    padding: 0 10px;
    background: color-mix(in srgb, var(--surface-color) 92%, var(--bg-color));
}

.workbench-tab {
    border-radius: var(--gv-radius-md) var(--gv-radius-md) 0 0;
    padding: 0 10px;
}

.workbench-tab:hover {
    transform: translateY(-1px);
}

.workbench-tab.is-active {
    box-shadow: inset 0 1px 0 color-mix(in srgb, var(--node-color) 26%, transparent);
}

.sidebar-panel-header {
    padding: 11px 12px;
}

.sidebar-panel-title {
    letter-spacing: 0.05em;
}

.info-bar {
    border-bottom-color: color-mix(in srgb, var(--border-color) 82%, transparent);
}

.info-bar-header {
    min-height: 34px;
}

.info-bar-content {
    gap: 3px;
    padding: 0 12px 10px;
}

.info-bar-row {
    border-radius: 6px;
    padding: 4px 6px;
}

.commit-search {
    border-radius: var(--gv-radius-md);
    background: color-mix(in srgb, var(--surface-color) 92%, var(--bg-color));
}

.commit-search:focus-within,
.commit-search.is-focused,
.repo-landing__input:focus,
.analytics-period-input:focus,
.merge-preview-select:focus {
    box-shadow: var(--gv-focus);
}

.commit-search-dropdown {
    border-radius: var(--gv-radius-md);
}

.repo-landing {
    padding: 0 28px 0;
}

.repo-landing__hero {
    padding: 72px 0 56px;
}

.repo-landing__section {
    padding: 42px 0;
}

.repo-landing__card,
.repo-landing__item,
.repo-landing__code-block {
    border-radius: var(--gv-radius-md);
    box-shadow: 0 1px 0 color-mix(in srgb, var(--surface-color) 70%, transparent);
}

.repo-landing__card--ready:hover,
.repo-landing__item--ready:hover {
    transform: translateY(-1px);
}

.repo-landing__cta-primary,
.repo-landing__add-btn,
.repo-landing__card-cta {
    border-radius: var(--gv-radius-sm);
}

.repo-landing__cta-secondary,
.repo-landing__input,
.repo-landing__copy-btn,
.back-to-repos {
    border-radius: var(--gv-radius-sm);
}

.connection-banner {
    border-radius: var(--gv-radius-lg);
    border: 1px solid color-mix(in srgb, var(--border-color) 84%, transparent);
}

.graph-minimap {
    border-radius: var(--gv-radius-md);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
}

@media (max-width: 480px) {
    .repo-landing {
        padding: 0 16px 0;
    }

    .repo-landing__hero {
        padding: 44px 0 36px;
    }

    .repo-landing__section {
        padding: 30px 0;
    }
}

/* ── Hard theme sync for Dockview + key panels ─────────────────────────── */

/*
 * Dockview creates drag-preview/overlay elements that may be mounted outside
 * .workbench-dock. Keep theme vars on :root so those elements inherit correctly.
 */
:root {
    --dv-background-color: var(--surface-color);
    --dv-separator-border: var(--border-color);
    --dv-tab-divider-color: var(--border-color);
    --dv-tabs-and-actions-container-background-color: color-mix(in srgb, var(--surface-color) 88%, var(--bg-color));
    --dv-activegroup-visiblepanel-tab-background-color: var(--surface-color);
    --dv-activegroup-visiblepanel-tab-color: var(--text-color);
    --dv-activegroup-hiddenpanel-tab-background-color: color-mix(in srgb, var(--surface-color) 90%, var(--bg-color));
    --dv-activegroup-hiddenpanel-tab-color: var(--text-secondary);
    --dv-inactivegroup-visiblepanel-tab-background-color: color-mix(in srgb, var(--surface-color) 90%, var(--bg-color));
    --dv-inactivegroup-visiblepanel-tab-color: var(--text-secondary);
    --dv-inactivegroup-hiddenpanel-tab-background-color: color-mix(in srgb, var(--surface-color) 92%, var(--bg-color));
    --dv-inactivegroup-hiddenpanel-tab-color: var(--text-secondary);
}

/* Ensure panel roots always paint with current theme surface */
.index-view,
.file-explorer,
.staging-view,
.merge-preview-view,
.merge-preview-file-list,
.merge-preview-branch-selectors,
.sidebar-panel-content,
.sidebar-panel-tab-content {
    background: var(--surface-color);
    color: var(--text-color);
}

/* Dockview theme variables (acts as source of truth for tab/panel chrome) */
.workbench-dock {
    --dv-background-color: var(--surface-color);
    --dv-separator-border: var(--border-color);
    --dv-tab-divider-color: var(--border-color);
    --dv-tabs-and-actions-container-background-color: color-mix(in srgb, var(--surface-color) 88%, var(--bg-color));
    --dv-activegroup-visiblepanel-tab-background-color: var(--surface-color);
    --dv-activegroup-visiblepanel-tab-color: var(--text-color);
    --dv-activegroup-hiddenpanel-tab-background-color: color-mix(in srgb, var(--surface-color) 90%, var(--bg-color));
    --dv-activegroup-hiddenpanel-tab-color: var(--text-secondary);
    --dv-inactivegroup-visiblepanel-tab-background-color: color-mix(in srgb, var(--surface-color) 90%, var(--bg-color));
    --dv-inactivegroup-visiblepanel-tab-color: var(--text-secondary);
    --dv-inactivegroup-hiddenpanel-tab-background-color: color-mix(in srgb, var(--surface-color) 92%, var(--bg-color));
    --dv-inactivegroup-hiddenpanel-tab-color: var(--text-secondary);
}

/* Fallback hard overrides for Dockview classnames across versions */
.workbench-dock [class*="dv-"] {
    color: inherit;
}

.workbench-dock .dv-groupview,
.workbench-dock .dv-group-container,
.workbench-dock .dv-content-container,
.workbench-dock .dv-tabs-and-actions-container,
.workbench-dock .dv-panel-container {
    background: var(--surface-color) !important;
    border-color: var(--border-color) !important;
}

.workbench-dock .dv-tabs-and-actions-container {
    background: color-mix(in srgb, var(--surface-color) 88%, var(--bg-color)) !important;
}

.workbench-dock .dv-tab {
    color: var(--text-secondary) !important;
}

.workbench-dock .dv-tab:hover {
    color: var(--text-color) !important;
    background: color-mix(in srgb, var(--node-color) 8%, transparent) !important;
}

.workbench-dock .dv-active-tab,
.workbench-dock .dv-tab.dv-active-tab,
.workbench-dock .dv-tab[aria-selected="true"] {
    color: var(--text-color) !important;
    background: var(--surface-color) !important;
}

.workbench-dock .dv-sash,
.workbench-dock .dv-separator,
.workbench-dock .dv-tab-divider {
    border-color: var(--border-color) !important;
    background-color: color-mix(in srgb, var(--border-color) 65%, transparent) !important;
}

/* Dragging states / previews */
.dv-drag-image,
.dv-drag-and-drop-overlay,
.dv-drop-target,
.dv-drop-target-preview {
    background: var(--surface-color) !important;
    border-color: var(--border-color) !important;
    color: var(--text-color) !important;
}

.dv-drag-image .dv-tab,
.dv-drag-image [class*="dv-tab"] {
    background: var(--surface-color) !important;
    color: var(--text-color) !important;
    border-color: var(--border-color) !important;
}

/* Dockview clickable tabs ("Graph", "Repository", close X) */
.workbench-dock [role="tablist"] {
    background: color-mix(in srgb, var(--surface-color) 88%, var(--bg-color)) !important;
    border-color: var(--border-color) !important;
}

.workbench-dock [role="tab"] {
    background: color-mix(in srgb, var(--surface-color) 90%, var(--bg-color)) !important;
    color: var(--text-secondary) !important;
    border-color: var(--border-color) !important;
}

.workbench-dock [role="tab"]:hover {
    background: color-mix(in srgb, var(--node-color) 8%, var(--surface-color)) !important;
    color: var(--text-color) !important;
}

.workbench-dock [role="tab"][aria-selected="true"] {
    background: var(--surface-color) !important;
    color: var(--text-color) !important;
    box-shadow: inset 0 1px 0 color-mix(in srgb, var(--node-color) 26%, transparent) !important;
}

.workbench-dock [role="tab"] button,
.workbench-dock [role="tab"] [aria-label*="Close"],
.workbench-dock [role="tab"] [title*="Close"] {
    color: var(--text-secondary) !important;
    background: transparent !important;
}

.workbench-dock [role="tab"]:hover button,
.workbench-dock [role="tab"]:hover [aria-label*="Close"],
.workbench-dock [role="tab"]:hover [title*="Close"] {
    color: var(--text-color) !important;
}

/* Dockview inactive/hidden tabs: force theme correctness via Dockview classes */
.dockview-theme-light .dv-tabs-and-actions-container,
.dockview-theme-dark .dv-tabs-and-actions-container {
    background: color-mix(in srgb, var(--surface-color) 88%, var(--bg-color)) !important;
    border-color: var(--border-color) !important;
}

.dockview-theme-light .dv-tab,
.dockview-theme-dark .dv-tab {
    background: color-mix(in srgb, var(--surface-color) 90%, var(--bg-color)) !important;
    color: var(--text-secondary) !important;
    border-color: var(--border-color) !important;
}

.dockview-theme-light .dv-tab:hover,
.dockview-theme-dark .dv-tab:hover {
    background: color-mix(in srgb, var(--node-color) 8%, var(--surface-color)) !important;
    color: var(--text-color) !important;
}

.dockview-theme-light .dv-tab.dv-active-tab,
.dockview-theme-dark .dv-tab.dv-active-tab,
.dockview-theme-light .dv-tab[aria-selected="true"],
.dockview-theme-dark .dv-tab[aria-selected="true"] {
    background: var(--surface-color) !important;
    color: var(--text-color) !important;
}

/* Ensure close icon in inactive tabs also follows theme */
.dockview-theme-light .dv-tab button,
.dockview-theme-dark .dv-tab button,
.dockview-theme-light .dv-tab [aria-label*="Close"],
.dockview-theme-dark .dv-tab [aria-label*="Close"],
.dockview-theme-light .dv-tab [title*="Close"],
.dockview-theme-dark .dv-tab [title*="Close"] {
    color: inherit !important;
    background: transparent !important;
}

/* ── 2026 UX/Visual pass: Technical Editorial direction ──────────────── */

:root {
    --gv-font-display: "Iowan Old Style", "Palatino Linotype", Palatino, "Book Antiqua", serif;
    --gv-font-ui: "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --gv-font-mono: "JetBrains Mono", "SFMono-Regular", Menlo, Consolas, monospace;
    --gv-space-1: 4px;
    --gv-space-2: 8px;
    --gv-space-3: 12px;
    --gv-space-4: 16px;
    --gv-space-5: 24px;
    --gv-space-6: 32px;
    --gv-panel-shadow: 0 16px 40px color-mix(in srgb, var(--node-shadow-color) 66%, transparent);
    --gv-card-shadow: 0 10px 24px color-mix(in srgb, var(--node-shadow-color) 42%, transparent);
}

body {
    font-family: var(--gv-font-ui);
    background:
        radial-gradient(900px 460px at 12% -18%, color-mix(in srgb, var(--node-color) 14%, transparent), transparent 72%),
        radial-gradient(1000px 520px at 110% 110%, color-mix(in srgb, var(--merge-node-color) 10%, transparent), transparent 75%),
        var(--bg-color);
}

#root {
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--surface-color) 98%, transparent), var(--surface-color)),
        var(--surface-color);
}

.activity-bar {
    gap: var(--gv-space-1);
    padding-top: var(--gv-space-2);
    background: color-mix(in srgb, var(--surface-recessed) 92%, var(--surface-color));
}

.activity-bar-icon {
    border: 1px solid transparent;
}

.activity-bar-icon:hover,
.activity-bar-icon.is-active {
    border-color: color-mix(in srgb, var(--node-color) 24%, var(--border-color));
    background: color-mix(in srgb, var(--node-color) 13%, transparent);
}

.workbench-tabbar {
    border-bottom: 1px solid color-mix(in srgb, var(--border-color) 78%, transparent);
}

.workbench-tab {
    min-width: 104px;
    height: 33px;
}

.workbench-tab-label {
    font-family: var(--gv-font-mono);
    letter-spacing: 0.01em;
}

.sidebar-panel {
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--surface-color) 96%, var(--bg-color)), var(--surface-color));
}

.sidebar-panel-title {
    font-family: var(--gv-font-mono);
    font-size: 11px;
    letter-spacing: 0.08em;
}

.sidebar-panel-header {
    border-bottom-color: color-mix(in srgb, var(--border-color) 74%, transparent);
}

.repo-landing {
    position: relative;
    width: 100%;
    min-height: 100vh;
    padding: 0 var(--gv-space-5) 48px;
    --gv-nav-height: 54px;
    --gv-nav-clearance: calc(var(--gv-nav-height) + 22px);
}

.repo-landing::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    background-image:
        linear-gradient(to right, color-mix(in srgb, var(--border-color) 24%, transparent) 1px, transparent 1px),
        linear-gradient(to bottom, color-mix(in srgb, var(--border-color) 18%, transparent) 1px, transparent 1px);
    background-size: 48px 48px;
    opacity: 0.22;
    mask-image: radial-gradient(circle at center, black 36%, transparent 88%);
}

.repo-landing__chrome,
.repo-docs__chrome,
.repo-install__chrome,
.repo-loading__chrome {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 20;
    padding-top: 10px;
    padding-left: var(--gv-space-5);
    padding-right: var(--gv-space-5);
    pointer-events: none;
}

.repo-landing__topbar {
    position: relative;
    display: flex;
    justify-content: center;
    width: 100%;
    pointer-events: auto;
    animation: gv-reveal-up 320ms cubic-bezier(0.22, 1, 0.36, 1) both;
}

.repo-landing__content {
    width: min(100%, 1080px);
    margin: 0 auto;
    padding-top: var(--gv-nav-clearance);
    display: grid;
    gap: clamp(72px, 8vw, 104px);
}

.repo-landing__hero,
.repo-landing__proof-strip,
.repo-landing__section,
.repo-landing__footer {
    width: 100%;
    max-width: 1080px;
    scroll-margin-top: calc(var(--gv-nav-clearance) + 12px);
}

.repo-landing__topbar-nav {
    position: relative;
    width: min(100%, 1080px);
    min-height: var(--gv-nav-height);
    --gv-nav-divider-gap: 24px;
    padding: 0 22px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    border: 1px solid color-mix(in srgb, var(--border-color) 76%, transparent);
    border-radius: 28px;
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--surface-elevated) 94%, transparent), color-mix(in srgb, var(--surface-color) 92%, transparent));
    box-shadow:
        0 16px 36px color-mix(in srgb, var(--node-shadow-color) 20%, transparent),
        inset 0 1px 0 color-mix(in srgb, var(--surface-color) 76%, transparent);
    backdrop-filter: blur(18px) saturate(1.08);
}

.repo-landing__topbar-nav::before,
.repo-landing__topbar-nav::after {
    content: none;
}

.repo-landing__brand {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    flex: 0 1 auto;
    min-width: 0;
    color: inherit;
    text-decoration: none;
    border-radius: 18px;
    transition: transform 160ms ease, background-color 160ms ease, color 160ms ease;
}

.repo-landing__brand:hover,
.repo-landing__brand:focus-visible {
    color: var(--text-color);
}

.repo-landing__brand-mark {
    width: 28px;
    height: 28px;
    flex: 0 0 auto;
    filter: drop-shadow(0 8px 16px color-mix(in srgb, var(--node-color) 14%, transparent));
}

.repo-landing__brand-copy {
    display: grid;
    gap: 2px;
    min-width: 0;
}

.repo-landing__brand-copy strong {
    font-family: var(--gv-font-display);
    font-size: 18px;
    line-height: 1;
    letter-spacing: -0.03em;
    color: var(--text-color);
}

.repo-landing__brand-copy span {
    font-family: var(--gv-font-mono);
    font-size: 10px;
    line-height: 1.2;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.repo-landing__topbar-links {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: var(--gv-nav-divider-gap);
    margin-left: auto;
}

.repo-landing__nav-link,
.repo-landing__hero-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--gv-font-mono);
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-secondary);
    text-decoration: none;
    transition: color 160ms ease, border-color 160ms ease, background-color 160ms ease, transform 160ms ease;
}

.repo-landing__nav-link {
    position: relative;
    min-height: 34px;
    padding: 0 20px;
    border: 1px solid transparent;
    border-radius: 999px;
    white-space: nowrap;
}

.repo-landing__nav-link + .repo-landing__nav-link::before {
    content: "";
    position: absolute;
    left: calc(var(--gv-nav-divider-gap) * -0.5);
    top: 50%;
    width: 1px;
    height: 18px;
    background: linear-gradient(
        180deg,
        transparent,
        color-mix(in srgb, var(--border-color) 82%, var(--node-color)),
        transparent
    );
    transform: translate(-0.5px, -50%);
    opacity: 0.9;
    transition: opacity 160ms ease, transform 160ms ease;
}

.repo-landing__nav-link::after {
    content: "";
    position: absolute;
    left: 14px;
    right: 14px;
    bottom: 3px;
    height: 2px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--node-color), color-mix(in srgb, var(--merge-node-color) 72%, var(--node-color)));
    transform: scaleX(0.24);
    transform-origin: center;
    opacity: 0;
    transition: transform 180ms ease, opacity 180ms ease;
}

.repo-landing__nav-link:hover,
.repo-landing__nav-link:focus-visible {
    color: var(--text-color);
    background: color-mix(in srgb, var(--surface-color) 72%, transparent);
}

.repo-landing__nav-link:hover::before,
.repo-landing__nav-link:focus-visible::before {
    opacity: 0.4;
    transform: translate(-0.5px, -50%) scaleY(0.8);
}

.repo-landing__nav-link:hover::after,
.repo-landing__nav-link:focus-visible::after {
    transform: scaleX(1);
    opacity: 1;
}

.repo-landing__nav-link:focus-visible,
.repo-landing__brand:focus-visible,
.repo-landing__cta-primary:focus-visible,
.repo-landing__cta-secondary:focus-visible,
.repo-landing__scroll-cue:focus-visible,
.repo-landing__hero-link:focus-visible,
.repo-landing__card-cta:focus-visible,
.repo-landing__copy-btn:focus-visible,
.repo-landing__footer-link:focus-visible {
    outline: 2px solid var(--node-color);
    outline-offset: 2px;
}

.repo-landing__hero {
    --gv-hero-pad-top: 20px;
    --gv-hero-pad-bottom: 72px;
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) clamp(220px, 28vw, 360px);
    gap: 36px;
    align-items: stretch;
    min-height: calc(100vh - var(--gv-nav-clearance) - var(--gv-space-6));
    min-height: calc(100dvh - var(--gv-nav-clearance) - var(--gv-space-6));
    padding: var(--gv-hero-pad-top) 0 var(--gv-hero-pad-bottom);
    text-align: left;
    overflow: visible;
}

.repo-landing__hero::before {
    content: "";
    position: absolute;
    inset: -32px -48px -24px -36px;
    pointer-events: none;
    background:
        radial-gradient(circle at 78% 22%, color-mix(in srgb, var(--node-color) 9%, transparent) 0%, transparent 30%),
        radial-gradient(circle at 62% 58%, color-mix(in srgb, var(--node-color) 5%, transparent) 0%, transparent 36%),
        linear-gradient(90deg, color-mix(in srgb, var(--node-color) 2%, transparent) 0%, transparent 46%);
    opacity: 1;
    -webkit-mask-image:
        linear-gradient(180deg, transparent 0%, #000 10%, #000 74%, transparent 100%),
        linear-gradient(90deg, transparent 0%, #000 9%, #000 91%, transparent 100%);
    -webkit-mask-composite: source-in;
    mask-image:
        linear-gradient(180deg, transparent 0%, #000 10%, #000 74%, transparent 100%),
        linear-gradient(90deg, transparent 0%, #000 9%, #000 91%, transparent 100%);
    mask-composite: intersect;
    z-index: 0;
}

.repo-landing__hero-copy,
.repo-landing__hero-preview {
    position: relative;
    z-index: 1;
    animation: gv-reveal-up 360ms cubic-bezier(0.22, 1, 0.36, 1) both;
}

.repo-landing__hero-copy {
    display: grid;
    align-content: center;
    gap: 0;
    min-height: 100%;
    padding: 12px 0;
}

.repo-landing__hero-preview {
    position: relative;
    display: flex;
    justify-content: flex-end;
    align-items: stretch;
    animation-delay: 90ms;
    width: 100%;
    max-width: none;
    min-height: 100%;
    margin-bottom: calc(var(--gv-hero-pad-bottom) * -1);
    justify-self: stretch;
    pointer-events: none;
}

.repo-landing__scroll-cue {
    position: absolute;
    left: 50%;
    bottom: 36px;
    transform: translateX(-50%);
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    min-width: 112px;
    padding: 12px 16px 10px;
    border: 1px solid color-mix(in srgb, var(--border-color) 74%, transparent);
    border-radius: 999px;
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--surface-elevated) 88%, transparent), color-mix(in srgb, var(--surface-color) 78%, transparent));
    box-shadow:
        0 14px 32px color-mix(in srgb, var(--node-shadow-color) 12%, transparent),
        inset 0 1px 0 color-mix(in srgb, var(--surface-elevated) 82%, transparent);
    backdrop-filter: blur(14px) saturate(1.05);
    cursor: pointer;
    opacity: 1;
    transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease, color 180ms ease, opacity 180ms ease;
    z-index: 2;
}

.repo-landing__scroll-cue:hover,
.repo-landing__scroll-cue:focus-visible {
    transform: translateX(-50%) translateY(-2px);
    border-color: color-mix(in srgb, var(--node-color) 34%, var(--border-color));
    box-shadow:
        0 18px 38px color-mix(in srgb, var(--node-shadow-color) 16%, transparent),
        inset 0 1px 0 color-mix(in srgb, var(--surface-elevated) 88%, transparent);
}

.repo-landing__scroll-cue--hidden {
    opacity: 0;
    pointer-events: none;
    transform: translateX(-50%) translateY(8px);
}

.repo-landing__scroll-cue-label {
    font-family: var(--gv-font-mono);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.repo-landing__scroll-cue-arrow {
    width: 12px;
    height: 12px;
    margin-top: -8px;
    border-right: 1.5px solid color-mix(in srgb, var(--text-color) 88%, transparent);
    border-bottom: 1.5px solid color-mix(in srgb, var(--text-color) 88%, transparent);
    transform: rotate(45deg);
    animation: gv-scroll-nudge 1.8s ease-in-out infinite;
    transform-origin: center;
    opacity: 0.92;
}

.repo-landing__eyebrow {
    font-family: var(--gv-font-mono);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-secondary);
    margin: 0 0 16px;
}

.repo-landing__title {
    font-family: var(--gv-font-display);
    font-size: clamp(42px, 5vw, 68px);
    letter-spacing: -0.035em;
    line-height: 0.95;
    max-width: 8.5ch;
}

.repo-landing__tagline {
    font-size: clamp(17px, 1.9vw, 19px);
    line-height: 1.68;
    color: var(--text-secondary);
    max-width: 50ch;
    margin-top: 22px;
}

.repo-landing__hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 14px;
}

.repo-landing__cta-primary,
.repo-landing__cta-secondary,
.repo-landing__hero-link {
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, color 180ms ease, background-color 180ms ease;
}

.repo-landing__cta-primary:hover,
.repo-landing__cta-secondary:hover,
.repo-landing__card-cta:hover,
.repo-landing__hero-link:hover {
    transform: translateY(-1px);
}

.repo-landing__hero-form-shell {
    margin-top: 28px;
    padding: 20px;
    border-radius: 18px;
    border: 1px solid color-mix(in srgb, var(--border-color) 88%, transparent);
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--surface-elevated) 98%, transparent), color-mix(in srgb, var(--surface-color) 92%, var(--bg-color)));
    box-shadow:
        inset 0 1px 0 color-mix(in srgb, var(--surface-elevated) 82%, transparent),
        var(--gv-panel-shadow);
}

.repo-landing__try-section {
    padding-top: 0;
}

.repo-landing__try-section .repo-landing__hero-form-shell {
    max-width: 820px;
    margin: 0 auto;
}

.repo-landing__hero-form-lead {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 14px;
}

.repo-landing__hero-form-lead strong {
    font-family: var(--gv-font-display);
    font-size: clamp(24px, 3vw, 32px);
    line-height: 1;
}

.repo-landing__hero-form-lead span,
.repo-landing__hero-support {
    color: var(--text-secondary);
    line-height: 1.5;
}

.repo-landing__form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
    width: 100%;
    max-width: none;
    margin-bottom: 0;
}

.repo-landing__input-shell {
    position: relative;
    min-width: 0;
}

.repo-landing__input {
    width: 100%;
    min-height: 52px;
    padding: 0 16px;
    border-radius: 12px;
    border: 1px solid color-mix(in srgb, var(--border-color) 88%, transparent);
    background: color-mix(in srgb, var(--surface-color) 98%, var(--bg-color));
    box-shadow: inset 0 1px 0 color-mix(in srgb, var(--surface-elevated) 78%, transparent);
    font-family: var(--gv-font-mono);
    font-size: 14px;
    letter-spacing: 0.01em;
}

.repo-landing__input-sample {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    padding: 0 16px;
    overflow: hidden;
    pointer-events: none;
    color: color-mix(in srgb, var(--text-secondary) 88%, transparent);
    transition: opacity 140ms ease;
}

.repo-landing__input-sample--hidden {
    opacity: 0;
}

.repo-landing__input-sample-text {
    display: block;
    max-width: 100%;
    font-family: var(--gv-font-mono);
    font-size: 14px;
    letter-spacing: 0.01em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    opacity: 0;
    transform: translateY(-130%);
}

.repo-landing__input-sample--animate .repo-landing__input-sample-text {
    animation: gv-repo-input-sample 2.55s cubic-bezier(0.3, 0, 0.2, 1) forwards;
}

.repo-landing__add-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 52px;
    padding: 0 20px 0 22px;
    border-radius: 12px;
    border: 1px solid color-mix(in srgb, var(--node-color) 48%, transparent);
    background: linear-gradient(135deg, color-mix(in srgb, var(--node-color) 96%, #ffffff), color-mix(in srgb, var(--merge-node-color) 36%, var(--node-color)));
    box-shadow:
        inset 0 1px 0 color-mix(in srgb, #ffffff 42%, transparent),
        0 12px 24px color-mix(in srgb, var(--node-color) 14%, transparent);
    color: #ffffff;
    font-family: var(--gv-font-mono);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    white-space: nowrap;
}

.repo-landing__add-btn::after {
    content: "\2192";
    font-size: 16px;
    line-height: 1;
    transition: transform 180ms ease;
}

.repo-landing__cta-secondary {
    min-height: 44px;
    padding: 0 16px;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--border-color) 76%, transparent);
    background: color-mix(in srgb, var(--surface-color) 94%, transparent);
    box-shadow: var(--gv-card-shadow);
    color: var(--text-color);
    font-family: var(--gv-font-mono);
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.repo-landing__add-btn:hover {
    opacity: 1;
    transform: translateY(-1px);
    box-shadow:
        inset 0 1px 0 color-mix(in srgb, #ffffff 48%, transparent),
        0 16px 30px color-mix(in srgb, var(--node-color) 18%, transparent);
}

.repo-landing__add-btn:hover::after,
.repo-landing__add-btn:focus-visible::after {
    transform: translateX(2px);
}

.repo-landing__cta-secondary:hover {
    border-color: color-mix(in srgb, var(--node-color) 28%, var(--border-color));
    color: var(--text-color);
}

.repo-landing__hero-form-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    margin-top: 12px;
}

.repo-landing__hero-link {
    padding: 0;
    border: none;
    background: transparent;
    cursor: pointer;
}

.repo-landing__hero-link:hover,
.repo-landing__hero-link:focus-visible {
    color: var(--text-color);
}

.repo-landing__error {
    min-height: 20px;
    max-width: none;
    margin-top: 10px;
}

.repo-landing__list--hero {
    max-width: none;
    margin-top: 18px;
}

.repo-landing__list-heading,
.repo-landing__card-name,
.repo-landing__footer-license {
    font-family: var(--gv-font-mono);
}

.repo-landing__preview-frame {
    position: relative;
    width: 100%;
    height: 100%;
    min-height: calc(100vh - var(--gv-nav-clearance) - var(--gv-hero-pad-top));
    min-height: calc(100dvh - var(--gv-nav-clearance) - var(--gv-hero-pad-top));
    aspect-ratio: 736 / 1738;
    min-width: 0;
    max-width: none;
    margin-right: 0;
    margin-left: auto;
    overflow: visible;
}

.repo-landing__preview-frame::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(90deg, color-mix(in srgb, var(--bg-color) 52%, transparent) 0%, color-mix(in srgb, var(--bg-color) 14%, transparent) 28%, transparent 46%),
        linear-gradient(180deg, transparent 0%, transparent 88%, color-mix(in srgb, var(--bg-color) 32%, transparent) 95%, var(--bg-color) 100%);
}

.repo-landing__preview-media {
    position: relative;
    inset: 0;
    width: 100%;
    height: 100%;
}

.repo-landing__preview-picture {
    display: block;
    width: 100%;
    height: 100%;
}

.repo-landing__preview-image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top left;
    border-radius: 0;
    border: none;
    box-shadow: none;
    background: transparent;
}

.repo-landing__proof-strip {
    position: relative;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    align-content: center;
    padding: 28px 0 8px;
    animation: gv-reveal-up 360ms cubic-bezier(0.22, 1, 0.36, 1) both;
    animation-delay: 140ms;
}

.repo-landing__proof-strip::before {
    content: "";
    position: absolute;
    inset: 0;
    border-top: 1px solid color-mix(in srgb, var(--border-color) 68%, transparent);
    background:
        radial-gradient(circle at top center, color-mix(in srgb, var(--node-color) 8%, transparent), transparent 52%);
    pointer-events: none;
}

.repo-landing__proof-strip > * {
    position: relative;
    z-index: 1;
}

.repo-landing__proof-title,
.repo-landing__proof-intro {
    grid-column: 1 / -1;
}

.repo-landing__proof-title {
    max-width: 14ch;
}

.repo-landing__proof-intro {
    max-width: 58ch;
    margin: 2px 0 12px;
}

.repo-landing__proof-item {
    display: grid;
    align-content: start;
    gap: 10px;
    min-height: 180px;
    padding: 22px 22px 20px;
    border-radius: 20px;
    border: 1px solid color-mix(in srgb, var(--border-color) 74%, transparent);
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--surface-elevated) 96%, transparent), color-mix(in srgb, var(--surface-color) 92%, var(--bg-color)));
    box-shadow:
        0 18px 36px color-mix(in srgb, var(--node-shadow-color) 10%, transparent),
        inset 0 1px 0 color-mix(in srgb, var(--surface-elevated) 82%, transparent);
}

.repo-landing__proof-item::before {
    content: "";
    width: 36px;
    height: 2px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--node-color), color-mix(in srgb, var(--merge-node-color) 68%, var(--node-color)));
}

.repo-landing__proof-item strong {
    font-family: var(--gv-font-display);
    font-size: 22px;
    line-height: 1;
    letter-spacing: -0.02em;
}

.repo-landing__proof-item span,
.repo-landing__footer-brand span {
    color: var(--text-secondary);
    line-height: 1.6;
}

.repo-landing__section {
    padding: 0;
    animation: gv-reveal-up 360ms cubic-bezier(0.22, 1, 0.36, 1) both;
}

.repo-landing__featured {
    animation-delay: 200ms;
}

.repo-landing__install {
    display: grid;
    justify-items: start;
    gap: 16px;
    animation-delay: 250ms;
}

.repo-landing__install .repo-install__docs-link {
    margin-top: 0;
}

.repo-landing__section-title {
    font-family: var(--gv-font-display);
    font-size: clamp(28px, 3vw, 38px);
    line-height: 1.05;
    max-width: 18ch;
}

.repo-landing__section-subtitle {
    max-width: 70ch;
    margin-top: 10px;
    line-height: 1.65;
}

.repo-landing__featured-grid {
    margin-top: 28px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.repo-landing__card,
.repo-landing__item,
.repo-landing__code-block {
    border-radius: 18px;
    box-shadow: var(--gv-card-shadow);
}

.repo-landing__card {
    display: grid;
    grid-template-rows: auto auto auto;
    gap: 10px;
    min-height: 188px;
    padding: 22px;
    border-left: 3px solid color-mix(in srgb, var(--node-color) 35%, var(--border-color));
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--surface-elevated) 96%, transparent), color-mix(in srgb, var(--surface-color) 94%, var(--bg-color)));
}

.repo-landing__card,
.repo-landing__item {
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, outline-color 180ms ease;
}

.repo-landing__card--ready:hover,
.repo-landing__item--ready:hover {
    box-shadow: var(--gv-panel-shadow);
    transform: translateY(-2px);
}

.repo-landing__item:focus-visible,
.repo-landing__card:focus-visible {
    outline: 2px solid var(--node-color);
    outline-offset: 3px;
}

.repo-landing__highlighted {
    border-color: color-mix(in srgb, var(--node-color) 62%, var(--border-color));
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--node-color) 16%, transparent), var(--gv-panel-shadow);
}

.repo-landing__card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 2px;
}

.repo-landing__card-name,
.repo-landing__list-heading {
    font-family: var(--gv-font-mono);
}

.repo-landing__card-name {
    font-size: 13px;
    line-height: 1.35;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.repo-landing__card-desc {
    margin: 0;
    color: var(--text-secondary);
    font-size: 16px;
    line-height: 1.6;
}

.repo-landing__card-action {
    display: flex;
    align-items: flex-end;
    min-height: 0;
    padding-top: 2px;
}

.repo-landing__badge {
    border: 1px solid color-mix(in srgb, currentColor 42%, transparent);
    font-family: var(--gv-font-mono);
}

.repo-landing__card-cta,
.repo-landing__code-block,
.repo-landing__item {
    background: color-mix(in srgb, var(--surface-color) 94%, transparent);
}

.repo-landing__code-block {
    max-width: 760px;
    min-height: 82px;
    margin-top: 24px;
    padding: 18px 20px;
    align-items: center;
    border: 1px solid color-mix(in srgb, var(--border-color) 76%, transparent);
}

.repo-landing__code-block code {
    font-family: var(--gv-font-mono);
    font-size: 13px;
}

.repo-landing__copy-btn {
    width: 40px;
    height: 40px;
    border-radius: 12px;
}

.repo-landing__footer {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 18px 24px;
    padding: 32px 0 0;
    margin-top: 0;
    border-top: 1px solid color-mix(in srgb, var(--border-color) 78%, transparent);
    animation: gv-reveal-up 360ms cubic-bezier(0.22, 1, 0.36, 1) both;
    animation-delay: 300ms;
}

.repo-landing__footer-brand {
    display: flex;
    align-items: flex-start;
    gap: 12px;
}

.repo-landing__footer-mark {
    width: 24px;
    height: 24px;
    flex: 0 0 auto;
    margin-top: 1px;
    filter: drop-shadow(0 6px 14px color-mix(in srgb, var(--node-color) 14%, transparent));
}

.repo-landing__footer-copy {
    display: grid;
    gap: 6px;
}

.repo-landing__footer-brand strong {
    font-family: var(--gv-font-display);
    font-size: 24px;
    line-height: 1;
}

.repo-landing__footer-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
    gap: 16px;
}

.repo-landing__footer-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--text-secondary);
    text-decoration: none;
    font-family: var(--gv-font-mono);
    font-size: 12px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    transition: color 180ms ease, transform 180ms ease;
}

.repo-landing__footer-link:hover {
    transform: translateY(-1px);
    color: var(--text-color);
}

.repo-landing__footer-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 12px;
    margin-top: 4px;
}

.repo-landing__footer-meta-item {
    color: var(--text-secondary);
    font-family: var(--gv-font-mono);
    font-size: 11px;
    letter-spacing: 0.04em;
}

.repo-landing__footer-license {
    color: color-mix(in srgb, var(--text-color) 78%, var(--text-secondary));
}

.repo-landing__nav-link--active {
    color: var(--text-color);
    background: color-mix(in srgb, var(--surface-color) 72%, transparent);
}

.repo-landing__nav-link--active::after {
    transform: scaleX(1);
    opacity: 1;
}

.repo-docs {
    --gv-docs-max-width: 1080px;
    --gv-nav-height: 54px;
    --gv-nav-clearance: calc(var(--gv-nav-height) + 22px);
    --gv-docs-accent: color-mix(in srgb, var(--node-color) 72%, #7ad3ff);
    --gv-docs-accent-soft: color-mix(in srgb, var(--gv-docs-accent) 16%, transparent);
    --gv-docs-hairline: color-mix(in srgb, var(--border-color) 72%, transparent);
    --gv-docs-panel: color-mix(in srgb, var(--surface-elevated) 94%, rgba(255, 255, 255, 0.02));
    --gv-docs-panel-strong: color-mix(in srgb, var(--surface-elevated) 98%, rgba(255, 255, 255, 0.04));
    position: relative;
    flex: 1;
    min-height: 0;
    height: 100%;
    padding: 0 20px 48px;
    overflow-y: auto;
    overflow-x: hidden;
}

.repo-docs::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at top left, color-mix(in srgb, var(--gv-docs-accent) 14%, transparent), transparent 34%),
        linear-gradient(180deg, color-mix(in srgb, var(--surface-color) 86%, transparent), transparent 20%),
        linear-gradient(90deg, color-mix(in srgb, var(--border-color) 14%, transparent) 1px, transparent 1px),
        linear-gradient(color-mix(in srgb, var(--border-color) 12%, transparent) 1px, transparent 1px);
    background-size: auto, auto, 40px 40px, 40px 40px;
    background-position: 0 0, 0 0, center top, center top;
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.75), transparent 88%);
    z-index: 0;
}

.repo-install {
    --gv-install-max-width: 1080px;
    --gv-nav-height: 54px;
    --gv-nav-clearance: calc(var(--gv-nav-height) + 22px);
    flex: 1;
    min-height: 0;
    height: 100%;
    padding: 0 20px 48px;
    overflow-y: auto;
    overflow-x: hidden;
}

.repo-loading {
    --gv-loading-max-width: 1080px;
    --gv-nav-height: 54px;
    --gv-nav-clearance: calc(var(--gv-nav-height) + 22px);
    flex: 1;
    min-height: 0;
    height: 100%;
    padding: 0 20px 48px;
    overflow-y: auto;
    overflow-x: hidden;
}

.repo-install__content {
    width: min(100%, var(--gv-install-max-width));
    margin: 0 auto;
    padding-top: var(--gv-nav-clearance);
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
    gap: 28px;
}

.repo-loading__content {
    width: min(100%, var(--gv-loading-max-width));
    margin: 0 auto;
    padding-top: var(--gv-nav-clearance);
    display: grid;
    gap: 28px;
}

.repo-loading__hero,
.repo-loading__content > .repo-landing__footer {
    grid-column: 1 / -1;
}

.repo-loading__hero {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.9fr);
    gap: 24px;
    align-items: end;
}

.repo-loading__hero-copy,
.repo-loading__panel {
    animation: gv-reveal-up 360ms cubic-bezier(0.22, 1, 0.36, 1) both;
}

.repo-loading__eyebrow,
.repo-loading__panel-kicker,
.repo-loading__repo-id,
.repo-loading__badge,
.repo-loading__action {
    font-family: var(--gv-font-mono);
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.repo-loading__eyebrow,
.repo-loading__panel-kicker,
.repo-loading__repo-id {
    color: var(--text-secondary);
}

.repo-loading__title {
    margin: 14px 0 0;
    font-family: var(--gv-font-display);
    font-size: clamp(42px, 5vw, 68px);
    line-height: 0.97;
    letter-spacing: -0.04em;
    max-width: 10ch;
}

.repo-loading__lede,
.repo-loading__detail {
    color: var(--text-secondary);
    line-height: 1.72;
}

.repo-loading__lede {
    max-width: 56ch;
    margin: 22px 0 0;
    font-size: 18px;
}

.repo-loading__hero-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 24px;
}

.repo-loading__repo-id,
.repo-loading__badge {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--border-color) 76%, transparent);
    background: color-mix(in srgb, var(--surface-color) 90%, transparent);
}

.repo-loading__badge {
    color: var(--text-color);
}

.repo-loading__badge--pending,
.repo-loading__badge--cloning {
    border-color: color-mix(in srgb, var(--node-color) 32%, var(--border-color));
}

.repo-loading__badge--ready {
    border-color: color-mix(in srgb, var(--success-color) 34%, var(--border-color));
}

.repo-loading__badge--error {
    border-color: color-mix(in srgb, var(--danger-color) 38%, var(--border-color));
}

.repo-loading__panel {
    position: relative;
    padding: 24px;
    border-radius: 24px;
    border: 1px solid color-mix(in srgb, var(--border-color) 78%, transparent);
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--surface-elevated) 96%, transparent), color-mix(in srgb, var(--surface-color) 94%, transparent));
    box-shadow: var(--gv-card-shadow);
    overflow: hidden;
}

.repo-loading__panel::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at top right, color-mix(in srgb, var(--node-color) 16%, transparent), transparent 38%),
        linear-gradient(140deg, color-mix(in srgb, var(--surface-elevated) 14%, transparent), transparent 44%);
}

.repo-loading__panel > * {
    position: relative;
    z-index: 1;
}

.repo-loading__phase {
    margin-top: 12px;
    font-family: var(--gv-font-display);
    font-size: clamp(28px, 3vw, 38px);
    line-height: 1.04;
}

.repo-loading__percent {
    margin-top: 16px;
    font-family: var(--gv-font-mono);
    font-size: 14px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.repo-loading__progress-bar {
    height: 10px;
    margin-top: 10px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--surface-recessed) 90%, transparent);
    overflow: hidden;
}

.repo-loading__progress-fill {
    width: 0;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--node-color), color-mix(in srgb, var(--merge-node-color) 40%, var(--node-color)));
    box-shadow: 0 0 18px color-mix(in srgb, var(--node-color) 22%, transparent);
    transition: width 220ms ease;
}

.repo-loading__detail {
    margin-top: 14px;
    max-width: 42ch;
}

.repo-loading__detail--error {
    color: var(--danger-color);
}

.repo-loading__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 24px;
}

.repo-loading__action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 16px;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--border-color) 76%, transparent);
    background: color-mix(in srgb, var(--surface-color) 94%, transparent);
    color: var(--text-color);
    text-decoration: none;
    transition: transform 180ms ease, border-color 180ms ease, color 180ms ease;
}

.repo-loading__action--secondary {
    cursor: pointer;
}

.repo-loading__action:hover,
.repo-loading__action:focus-visible {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--node-color) 28%, var(--border-color));
    color: var(--text-color);
}

.repo-loading__content > .repo-landing__footer {
    margin-top: 4px;
}

.repo-install__hero,
.repo-install__install-block,
.repo-install__content > .repo-landing__footer {
    grid-column: 1 / -1;
}

.repo-install__hero {
    display: block;
}

.repo-install__hero-copy,
.repo-install__install-block {
    animation: gv-reveal-up 360ms cubic-bezier(0.22, 1, 0.36, 1) both;
}

.repo-install__panel-kicker,
.repo-install__section-label {
    font-family: var(--gv-font-mono);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-secondary);
}

.repo-install__title {
    margin: 22px 0 0;
    font-family: var(--gv-font-display);
    font-size: clamp(42px, 5vw, 68px);
    line-height: 0.93;
    letter-spacing: -0.04em;
    max-width: 10ch;
}

.repo-install__lede,
.repo-install__section-body,
.repo-install__command-note,
.repo-install__ordered-copy {
    color: var(--text-secondary);
    line-height: 1.72;
}

.repo-install__lede {
    max-width: 54ch;
    margin: 14px 0 0;
    font-size: 16px;
}

.repo-install__install-block {
    position: relative;
    padding: 24px;
    overflow: hidden;
    border: 1px solid color-mix(in srgb, var(--border-color) 78%, transparent);
    border-radius: 24px;
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--surface-elevated) 96%, transparent), color-mix(in srgb, var(--surface-color) 94%, transparent));
    box-shadow: var(--gv-card-shadow);
    animation-delay: 120ms;
}

.repo-install__install-block::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at top right, color-mix(in srgb, var(--node-color) 18%, transparent), transparent 36%),
        linear-gradient(135deg, color-mix(in srgb, var(--surface-elevated) 14%, transparent), transparent 42%);
}

.repo-install__install-block > * {
    position: relative;
    z-index: 1;
}

.repo-install__section-title {
    margin-top: 8px;
    font-family: var(--gv-font-display);
    line-height: 1.06;
    max-width: 14ch;
}

.repo-install__code-block {
    width: 100%;
    max-width: none;
    margin-top: 12px;
}

.repo-install__command-note {
    margin-top: 14px;
    max-width: 42ch;
}

.repo-install__section-title {
    font-size: clamp(24px, 2.8vw, 32px);
}

.repo-install__section-body {
    max-width: 78ch;
    margin-top: 10px;
}

.repo-install__ordered-step {
    display: grid;
    grid-template-columns: 32px minmax(0, 1fr);
    row-gap: 12px;
    gap: 16px;
    align-items: start;
    margin-top: 26px;
}

.repo-install__ordered-index {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--border-color) 76%, transparent);
    font-family: var(--gv-font-mono);
    font-size: 12px;
    color: var(--text-secondary);
}

.repo-install__ordered-body {
    min-width: 0;
}

.repo-install__ordered-title {
    margin: 1px 0 0;
    color: var(--text-color);
    font-weight: 600;
    line-height: 1.45;
}

.repo-install__ordered-copy {
    margin: 6px 0 0;
}

.repo-install__step-code {
    grid-column: 2;
    margin-top: 0;
    margin-right: 48px;
}

.repo-install__docs-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-top: 28px;
    color: var(--text-color);
    text-decoration: none;
    font-family: var(--gv-font-mono);
    font-size: 13px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    transition: color 180ms ease, transform 180ms ease;
}

.repo-install__docs-link::after {
    content: "->";
    color: var(--node-color);
}

.repo-install__docs-link:hover,
.repo-install__docs-link:focus-visible {
    color: var(--node-color);
    transform: translateX(2px);
}

.repo-install__docs-link:focus-visible {
    outline: 2px solid var(--node-color);
    outline-offset: 4px;
}

.repo-install__content > .repo-landing__footer {
    margin-top: 4px;
}

.repo-install__context-link:focus-visible {
    outline: 2px solid var(--node-color);
    outline-offset: 2px;
}

.repo-docs__content {
    position: relative;
    z-index: 1;
    width: min(100%, var(--gv-docs-max-width));
    margin: 0 auto;
    padding-top: calc(var(--gv-nav-clearance) + 12px);
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 28px;
}

.repo-docs__state {
    padding: 28px;
    border-radius: 26px;
    border: 1px solid var(--gv-docs-hairline);
    background: linear-gradient(180deg, var(--gv-docs-panel-strong), var(--gv-docs-panel));
    box-shadow: var(--gv-card-shadow), inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.repo-docs__state--error {
    color: var(--danger-color);
}

.repo-docs__content > .repo-landing__footer {
    margin-top: 0;
    padding-top: 24px;
    border-top: 0;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
}

.repo-docs__content > .repo-landing__footer .repo-landing__footer-links {
    justify-content: flex-end;
}

.repo-docs__page {
    display: grid;
    gap: 28px;
    grid-template-columns: 260px minmax(0, 1fr);
    align-items: start;
}

.repo-docs__header,
.repo-docs__toc,
.repo-docs__help,
.repo-docs__sidebar,
.repo-docs__section,
.repo-docs__toc-item {
    animation: gv-reveal-up 360ms cubic-bezier(0.22, 1, 0.36, 1) both;
    border: 1px solid var(--gv-docs-hairline);
    background: linear-gradient(180deg, var(--gv-docs-panel-strong), var(--gv-docs-panel));
    box-shadow: var(--gv-card-shadow), inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.repo-docs__eyebrow,
.repo-docs__section-label,
.repo-docs__sidebar-label {
    font-family: var(--gv-font-mono);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--text-secondary);
}

.repo-docs__title {
    margin: 12px 0 0;
    font-family: var(--gv-font-display);
    font-size: clamp(40px, 4.8vw, 68px);
    line-height: 0.95;
    letter-spacing: -0.05em;
    max-width: 14ch;
    text-wrap: balance;
}

.repo-docs__lede {
    max-width: 70ch;
    margin: 18px 0 0;
    font-size: 17px;
    line-height: 1.8;
    color: var(--text-secondary);
}

.repo-docs__lede--compact {
    max-width: 56ch;
}

.repo-docs__header,
.repo-docs__toc,
.repo-docs__help,
.repo-docs__section {
    padding: 32px;
    border-radius: 28px;
}

.repo-docs__sidebar,
.repo-docs__toc-item {
    border-radius: 24px;
}

.repo-docs__sidebar {
    position: sticky;
    top: calc(var(--gv-nav-clearance) + 8px);
    padding: 22px 18px;
    backdrop-filter: blur(16px);
}

.repo-docs__main {
    min-width: 0;
    display: grid;
    gap: 24px;
}

.repo-docs__header-meta,
.repo-docs__section-footer {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 16px;
    margin-top: 24px;
}

.repo-docs__breadcrumbs {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 10px;
}

.repo-docs__breadcrumb-link,
.repo-docs__breadcrumb-current {
    display: inline-flex;
    align-items: center;
    color: var(--text-secondary);
    font-family: var(--gv-font-mono);
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.repo-docs__breadcrumb-link {
    text-decoration: none;
    transition: color 180ms ease, transform 180ms ease;
}

.repo-docs__breadcrumb-link:hover,
.repo-docs__breadcrumb-link:focus-visible {
    color: var(--text-color);
    transform: translateY(-1px);
}

.repo-docs__breadcrumb-current {
    color: var(--text-color);
}

.repo-docs__breadcrumb-sep {
    color: color-mix(in srgb, var(--text-secondary) 64%, transparent);
    font-family: var(--gv-font-mono);
    font-size: 11px;
}

.repo-docs__context-link {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    font-family: var(--gv-font-mono);
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-secondary);
    transition: color 180ms ease, transform 180ms ease;
}

.repo-docs__context-link:hover,
.repo-docs__sidebar-link:hover {
    color: var(--text-color);
    transform: translateY(-1px);
}

.repo-docs__toc-title {
    margin: 0;
    font-family: var(--gv-font-display);
    font-size: clamp(28px, 2.8vw, 38px);
    line-height: 1.02;
    letter-spacing: -0.035em;
    max-width: 18ch;
}

.repo-docs__toc-list {
    display: grid;
    gap: 14px;
    margin-top: 22px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.repo-docs__sidebar-nav {
    display: grid;
    gap: 6px;
    margin-top: 14px;
}

.repo-docs__sidebar-link {
    display: block;
    padding: 10px 12px;
    border-radius: 14px;
    color: var(--text-secondary);
    text-decoration: none;
    font-size: 14px;
    line-height: 1.45;
    border: 1px solid transparent;
    transition: color 180ms ease, background-color 180ms ease, transform 180ms ease, border-color 180ms ease;
}

.repo-docs__sidebar-link[aria-current="page"],
.repo-docs__sidebar-link:hover,
.repo-docs__sidebar-link:focus-visible {
    color: var(--text-color);
    background: color-mix(in srgb, var(--gv-docs-accent) 8%, var(--surface-recessed));
    border-color: color-mix(in srgb, var(--gv-docs-accent) 16%, var(--border-color));
}

.repo-docs__sidebar-label--subnav {
    margin-top: 22px;
}

.repo-docs__sidebar-subnav {
    display: grid;
    gap: 4px;
    margin-top: 12px;
    padding-left: 12px;
    border-left: 1px solid var(--gv-docs-hairline);
}

.repo-docs__sidebar-sublink {
    display: block;
    color: var(--text-secondary);
    text-decoration: none;
    font-size: 13px;
    line-height: 1.45;
    padding: 5px 0;
    transition: color 180ms ease, transform 180ms ease;
}

.repo-docs__sidebar-sublink:hover,
.repo-docs__sidebar-sublink:focus-visible {
    color: var(--text-color);
    transform: translateX(2px);
}

.repo-docs__toc-item {
    position: relative;
    display: grid;
    gap: 12px;
    min-height: 220px;
    padding: 20px;
    color: inherit;
    text-decoration: none;
    transition: color 180ms ease, transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
    overflow: hidden;
}

.repo-docs__toc-item::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 2px;
    background: linear-gradient(90deg, var(--gv-docs-accent), transparent 72%);
    opacity: 0.8;
}

.repo-docs__toc-item:hover,
.repo-docs__toc-item:focus-visible {
    color: var(--text-color);
    transform: translateY(-2px);
    border-color: color-mix(in srgb, var(--gv-docs-accent) 18%, var(--border-color));
    box-shadow: var(--gv-card-shadow), 0 24px 50px rgba(0, 0, 0, 0.12);
}

.repo-docs__toc-item-kicker {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 26px;
    padding: 0 10px;
    border-radius: 999px;
    background: var(--gv-docs-accent-soft);
    color: var(--text-secondary);
    font-family: var(--gv-font-mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
}

.repo-docs__toc-item-title {
    display: block;
    font-family: var(--gv-font-display);
    font-size: clamp(22px, 2vw, 28px);
    line-height: 1.06;
    letter-spacing: -0.03em;
    color: var(--text-color);
    text-wrap: balance;
}

.repo-docs__toc-item-summary {
    display: block;
    color: var(--text-secondary);
    font-size: 15px;
    line-height: 1.75;
    max-width: 34ch;
}

.repo-docs__section-body {
    margin-top: 0;
    max-width: 68ch;
    line-height: 1.8;
    color: var(--text-secondary);
    font-size: 16px;
}

.repo-docs__copy + .repo-docs__copy {
    margin-top: 14px;
}

.repo-docs__copy code,
.repo-docs__list-item code,
.repo-docs__code code {
    font-family: var(--gv-font-mono);
    font-size: 0.95em;
    padding: 0.08em 0.35em;
    border-radius: 6px;
    background: color-mix(in srgb, var(--surface-recessed) 84%, transparent);
    color: var(--text-color);
}

.repo-docs__code {
    position: relative;
    margin-top: 24px;
    padding: 18px 52px 18px 18px;
    overflow-x: auto;
    border-radius: 22px;
    border: 1px solid color-mix(in srgb, var(--border-color) 76%, transparent);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.02), transparent 28%),
        color-mix(in srgb, var(--surface-recessed) 94%, transparent);
}

.repo-docs__code::before {
    content: attr(data-language);
    position: absolute;
    top: 12px;
    left: 16px;
    font-family: var(--gv-font-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: color-mix(in srgb, var(--text-secondary) 90%, transparent);
}

.repo-docs__code code {
    display: block;
    padding: 18px 0 0;
    border-radius: 0;
    background: transparent;
    line-height: 1.65;
    white-space: pre;
}

.repo-docs__copy-btn {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 32px;
    height: 32px;
    border: 1px solid color-mix(in srgb, var(--border-color) 78%, transparent);
    border-radius: 10px;
    background: color-mix(in srgb, var(--surface-color) 92%, transparent);
    color: var(--text-secondary);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: color 180ms ease, border-color 180ms ease, background-color 180ms ease;
}

.repo-docs__copy-btn:hover,
.repo-docs__copy-btn:focus-visible {
    color: var(--text-color);
    border-color: color-mix(in srgb, var(--node-color) 26%, var(--border-color));
    background: color-mix(in srgb, var(--surface-elevated) 96%, transparent);
}

.repo-docs__list {
    margin-top: 20px;
    padding-left: 0;
    color: var(--text-secondary);
    list-style: none;
}

.repo-docs__list .repo-docs__list {
    margin-top: 10px;
    margin-left: 18px;
}

.repo-docs__list li + li {
    margin-top: 10px;
}

.repo-docs__list-item {
    position: relative;
    padding-left: 26px;
    line-height: 1.7;
}

.repo-docs__list-item > p {
    margin: 0;
}

.repo-docs__list-item > p + p {
    margin-top: 8px;
}

.repo-docs__list-item > pre,
.repo-docs__list-item > .repo-docs__code,
.repo-docs__list-item > ul,
.repo-docs__list-item > ol {
    margin-top: 10px;
}

.repo-docs__list-item::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.72em;
    width: 7px;
    height: 7px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--text-secondary) 72%, var(--gv-docs-accent));
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--gv-docs-accent) 8%, transparent);
    transform: translateY(-50%);
}

ol.repo-docs__list,
.repo-docs__list ol {
    counter-reset: docs-steps;
}

ol.repo-docs__list > .repo-docs__list-item {
    padding-left: 42px;
}

ol.repo-docs__list > .repo-docs__list-item::before {
    counter-increment: docs-steps;
    content: counter(docs-steps);
    top: 0.1em;
    width: 26px;
    height: 26px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--gv-docs-accent) 20%, var(--border-color));
    background: color-mix(in srgb, var(--surface-recessed) 94%, transparent);
    color: var(--text-color);
    box-shadow: none;
    font-family: var(--gv-font-mono);
    font-size: 11px;
    line-height: 1;
    letter-spacing: 0.02em;
    transform: none;
}

.repo-docs__list ol > .repo-docs__list-item,
ol.repo-docs__list ol > .repo-docs__list-item {
    padding-left: 42px;
}

.repo-docs__list ol > .repo-docs__list-item::before,
ol.repo-docs__list ol > .repo-docs__list-item::before {
    counter-increment: docs-steps;
    content: counter(docs-steps);
    top: 0.1em;
    width: 26px;
    height: 26px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--gv-docs-accent) 20%, var(--border-color));
    background: color-mix(in srgb, var(--surface-recessed) 94%, transparent);
    color: var(--text-color);
    box-shadow: none;
    font-family: var(--gv-font-mono);
    font-size: 11px;
    line-height: 1;
    letter-spacing: 0.02em;
    transform: none;
}

.repo-docs__list ol .repo-docs__list-item + .repo-docs__list-item,
ol.repo-docs__list > .repo-docs__list-item + .repo-docs__list-item {
    margin-top: 14px;
}

.repo-docs__heading {
    color: var(--text-color);
    letter-spacing: -0.03em;
    text-wrap: balance;
}

.repo-docs__heading--h1,
.repo-docs__heading--h2 {
    font-family: var(--gv-font-display);
    margin: 36px 0 0;
    font-size: clamp(28px, 3vw, 40px);
    line-height: 1.04;
}

.repo-docs__heading--h3 {
    font-family: var(--gv-font-display);
    margin: 28px 0 0;
    font-size: clamp(20px, 2vw, 26px);
    line-height: 1.14;
}

.repo-docs__heading + .repo-docs__copy,
.repo-docs__heading + .repo-docs__list,
.repo-docs__heading + .repo-docs__code,
.repo-docs__heading + .repo-docs__quote,
.repo-docs__heading + .repo-docs__table-wrap {
    margin-top: 14px;
}

.repo-docs__list + .repo-docs__copy,
.repo-docs__list + .repo-docs__code,
.repo-docs__list + .repo-docs__quote,
.repo-docs__list + .repo-docs__table-wrap,
.repo-docs__list + .repo-docs__rule {
    margin-top: 20px;
}

.repo-docs__code + .repo-docs__copy,
.repo-docs__code + .repo-docs__list,
.repo-docs__code + .repo-docs__quote,
.repo-docs__code + .repo-docs__table-wrap,
.repo-docs__code + .repo-docs__rule {
    margin-top: 20px;
}

.repo-docs__inline-link {
    color: color-mix(in srgb, var(--gv-docs-accent) 78%, var(--text-color));
    text-decoration-color: color-mix(in srgb, var(--gv-docs-accent) 36%, transparent);
    text-decoration-thickness: 1px;
    text-underline-offset: 0.18em;
    transition: color 180ms ease, text-decoration-color 180ms ease;
}

.repo-docs__inline-link:hover,
.repo-docs__inline-link:focus-visible {
    color: var(--text-color);
    text-decoration-color: color-mix(in srgb, var(--gv-docs-accent) 76%, transparent);
}

.repo-docs__quote {
    margin: 24px 0 0;
    padding: 18px 18px 18px 22px;
    border-left: 3px solid var(--gv-docs-accent);
    border-radius: 0 18px 18px 0;
    background: color-mix(in srgb, var(--gv-docs-accent) 7%, var(--surface-recessed));
    color: var(--text-color);
}

.repo-docs__quote > :first-child {
    margin-top: 0;
}

.repo-docs__quote > :last-child {
    margin-bottom: 0;
}

.repo-docs__rule {
    margin: 32px 0;
    border: 0;
    border-top: 1px solid var(--gv-docs-hairline);
}

.repo-docs__table-wrap {
    margin-top: 24px;
    overflow-x: auto;
    border-radius: 20px;
    border: 1px solid var(--gv-docs-hairline);
    background: color-mix(in srgb, var(--surface-recessed) 94%, transparent);
}

.repo-docs__table {
    width: 100%;
    border-collapse: collapse;
}

.repo-docs__table th,
.repo-docs__table td {
    padding: 14px 16px;
    text-align: left;
    border-bottom: 1px solid var(--gv-docs-hairline);
}

.repo-docs__table th {
    font-family: var(--gv-font-mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--text-secondary);
}

.repo-docs__table tr:last-child td {
    border-bottom: 0;
}

.repo-docs__summary {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-top: 28px;
}

.repo-docs__summary-item {
    display: grid;
    gap: 10px;
    padding: 16px 18px;
    border-radius: 20px;
    border: 1px solid color-mix(in srgb, var(--gv-docs-accent) 10%, var(--border-color));
    background: color-mix(in srgb, var(--surface-recessed) 94%, transparent);
}

.repo-docs__summary-label {
    font-family: var(--gv-font-mono);
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.repo-docs__summary-value {
    font-size: 15px;
    line-height: 1.45;
    color: var(--text-color);
    font-weight: 600;
}

.repo-docs__help {
    display: grid;
    gap: 14px;
}

.repo-docs__pager {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-top: 8px;
    padding: 18px 0;
    border-top: 1px solid var(--gv-docs-hairline);
    border-bottom: 1px solid var(--gv-docs-hairline);
}

.repo-docs__pager-link {
    display: grid;
    gap: 4px;
    min-width: 0;
    padding: 2px 0;
    color: inherit;
    text-decoration: none;
    transition: color 180ms ease, transform 180ms ease;
}

.repo-docs__pager-link:hover,
.repo-docs__pager-link:focus-visible {
    transform: translateY(-1px);
}

.repo-docs__pager-link--next {
    justify-items: end;
    margin-left: auto;
}

.repo-docs__pager-label {
    font-family: var(--gv-font-mono);
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-color);
}

.repo-docs__pager-title {
    display: block;
    font-family: var(--gv-font-display);
    font-size: 18px;
    line-height: 1.15;
    letter-spacing: -0.02em;
    color: var(--text-color);
}

.repo-docs__pager-link--previous .repo-docs__pager-label::before {
    content: "<-";
    margin-right: 10px;
    color: var(--node-color);
}

.repo-docs__pager-link--next .repo-docs__pager-label::after {
    content: "->";
    margin-left: 10px;
    color: var(--node-color);
}

.repo-docs__primary-link {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 42px;
    padding: 0 16px;
    border-radius: 999px;
    text-decoration: none;
    color: #081018;
    background: linear-gradient(135deg, var(--gv-docs-accent), color-mix(in srgb, var(--gv-docs-accent) 70%, white));
    font-family: var(--gv-font-mono);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    transition: transform 180ms ease, box-shadow 180ms ease;
    box-shadow: 0 12px 28px color-mix(in srgb, var(--gv-docs-accent) 24%, transparent);
}

.repo-docs__primary-link:hover,
.repo-docs__primary-link:focus-visible {
    transform: translateY(-1px);
    box-shadow: 0 16px 32px color-mix(in srgb, var(--gv-docs-accent) 28%, transparent);
}

.repo-docs__context-link:focus-visible,
.repo-docs__sidebar-link:focus-visible,
.repo-docs__sidebar-sublink:focus-visible,
.repo-docs__toc-item:focus-visible,
.repo-docs__copy-btn:focus-visible,
.repo-docs__primary-link:focus-visible,
.repo-docs__inline-link:focus-visible {
    outline: 2px solid var(--node-color);
    outline-offset: 2px;
}

.back-to-repos {
    font-family: var(--gv-font-mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-radius: 999px;
    padding: 7px 12px;
}

.theme-toggle {
    right: 152px;
    bottom: 12px;
}

.gv-connection-indicator {
    position: fixed;
    right: 14px;
    bottom: 12px;
    z-index: 9999;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 32px;
    padding: 0 10px;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--border-color) 78%, transparent);
    background: color-mix(in srgb, var(--surface-elevated) 86%, transparent);
    color: var(--text-secondary);
    box-shadow: var(--gv-card-shadow);
    backdrop-filter: blur(6px);
    font-family: var(--gv-font-mono);
    font-size: 11px;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.gv-connection-indicator__light {
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: #8b949e;
}

.gv-connection-indicator[data-state="connected"] {
    color: var(--success-color);
}

.gv-connection-indicator[data-state="connected"] .gv-connection-indicator__light {
    background: var(--success-color);
    animation: gv-pulse-green 1.8s ease-out infinite;
}

.gv-connection-indicator[data-state="reconnecting"] {
    color: var(--warning-color);
}

.gv-connection-indicator[data-state="reconnecting"] .gv-connection-indicator__light {
    background: var(--warning-color);
    animation: gv-pulse-amber 0.9s ease-out infinite;
}

.gv-connection-indicator[data-state="disconnected"] {
    color: var(--danger-color);
}

.gv-connection-indicator[data-state="disconnected"] .gv-connection-indicator__light {
    background: var(--danger-color);
    animation: none;
}

@keyframes gv-reveal-up {
    from {
        opacity: 0;
        transform: translateY(8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes gv-pulse-green {
    0%, 100% {
        box-shadow: 0 0 0 0 color-mix(in srgb, var(--success-color) 40%, transparent);
    }
    50% {
        box-shadow: 0 0 0 5px color-mix(in srgb, var(--success-color) 0%, transparent);
    }
}

@keyframes gv-pulse-amber {
    0%, 100% {
        box-shadow: 0 0 0 0 color-mix(in srgb, var(--warning-color) 40%, transparent);
    }
    50% {
        box-shadow: 0 0 0 5px color-mix(in srgb, var(--warning-color) 0%, transparent);
    }
}

@media (max-width: 1080px) {
    .repo-landing__hero {
        grid-template-columns: minmax(0, 1fr) clamp(200px, 24vw, 300px);
        gap: 28px;
    }

    .repo-landing__preview-frame {
        max-width: none;
        margin-right: 0;
    }
}

@media (max-width: 630px) {
    .repo-landing__hero {
        min-height: auto;
        grid-template-columns: 1fr;
        gap: 24px;
        padding-bottom: 16px;
    }

    .repo-landing__hero-preview {
        display: none;
    }

    .repo-landing__scroll-cue {
        display: none;
    }

    .repo-landing__title,
    .repo-landing__section-title {
        max-width: none;
    }
}

@media (max-width: 760px) {
    .theme-toggle {
        right: 12px;
        bottom: 52px;
    }

    .repo-install__content,
    .repo-install__hero,
    .repo-loading__hero,
    .repo-install__ordered-step {
        grid-template-columns: 1fr;
    }

    .repo-loading__content,
    .repo-loading__content > .repo-landing__footer {
        grid-column: 1;
    }

    .repo-install__install-block,
    .repo-install__content > .repo-landing__footer {
        grid-column: 1;
    }

    .repo-install__code-block,
    .repo-install__section-body,
    .repo-install__ordered-body,
    .repo-install__ordered-title,
    .repo-install__ordered-copy {
        max-width: none;
    }

    .repo-install__step-code {
        grid-column: 1;
        margin-right: 0;
    }

    .repo-docs__page {
        grid-template-columns: 1fr;
    }

    .repo-docs__sidebar {
        position: static;
    }

    .repo-docs__toc-list,
    .repo-docs__summary,
    .repo-docs__pager {
        grid-template-columns: 1fr;
    }

    .repo-docs__pager {
        align-items: center;
    }

    .repo-docs__pager-link--next {
        margin-left: 0;
        justify-items: start;
    }

    .repo-docs__title {
        max-width: none;
    }

    .repo-landing__topbar-nav {
        gap: 12px;
        --gv-nav-divider-gap: 18px;
        padding-left: 14px;
        padding-right: 14px;
    }

    .repo-landing__brand-copy span {
        display: none;
    }

    .repo-landing__brand-copy strong {
        font-size: 16px;
    }

    .repo-landing__nav-link {
        padding: 0 16px;
    }

    .repo-landing__nav-link + .repo-landing__nav-link::before {
        content: "";
    }

    .repo-landing__proof-strip,
    .repo-landing__featured-grid,
    .repo-landing__footer {
        grid-template-columns: 1fr;
    }

    .repo-docs__content > .repo-landing__footer {
        grid-template-columns: minmax(0, 1fr) auto;
    }

    .repo-landing__proof-strip {
        min-height: auto;
    }

    .repo-landing__hero-form-meta {
        align-items: flex-start;
        flex-direction: column;
    }
}

@keyframes gv-scroll-nudge {
    0%,
    100% {
        transform: rotate(45deg) translate(0, 0);
        opacity: 0.72;
    }

    50% {
        transform: rotate(45deg) translate(2px, 2px);
        opacity: 1;
    }
}

@keyframes gv-repo-input-sample {
    0% {
        opacity: 0;
        transform: translateY(-130%);
    }

    18% {
        opacity: 1;
        transform: translateY(0);
    }

    64% {
        opacity: 1;
        transform: translateY(0);
    }

    100% {
        opacity: 0;
        transform: translateY(130%);
    }
}

@media (prefers-reduced-motion: reduce) {
    .repo-landing__input-sample-text,
    .repo-landing__input-sample--animate .repo-landing__input-sample-text {
        animation: none;
        opacity: 1;
        transform: translateY(0);
    }
}

@media (max-width: 560px) {
    .repo-landing {
        padding: 0 16px 36px;
    }

    .repo-docs {
        padding: 0 16px 36px;
    }

    .repo-install {
        padding: 0 16px 36px;
    }

    .repo-loading {
        padding: 0 16px 36px;
    }

    .repo-landing__chrome,
    .repo-docs__chrome,
    .repo-install__chrome,
    .repo-loading__chrome {
        padding-top: 12px;
        padding-left: 16px;
        padding-right: 16px;
    }

    .repo-landing__topbar-nav {
        --gv-nav-divider-gap: 14px;
        gap: 10px;
        padding-left: 10px;
        padding-right: 10px;
    }

    .repo-landing__brand {
        gap: 10px;
    }

    .repo-landing__brand-mark {
        width: 24px;
        height: 24px;
    }

    .repo-landing__nav-link {
        min-height: 32px;
        padding: 0 12px;
        font-size: 12px;
    }

    .repo-landing__hero-form-shell,
    .repo-landing__proof-item,
    .repo-landing__card,
    .repo-landing__item,
    .repo-landing__code-block,
    .repo-loading__panel,
    .repo-install__command-card,
    .repo-install__steps,
    .repo-install__step-card,
    .repo-docs__header,
    .repo-docs__toc,
    .repo-docs__help,
    .repo-docs__sidebar,
    .repo-docs__section,
    .repo-docs__toc-item {
        padding-left: 16px;
        padding-right: 16px;
    }

    .repo-landing__form {
        grid-template-columns: 1fr;
    }

    .repo-landing__add-btn,
    .repo-landing__cta-primary,
    .repo-landing__cta-secondary {
        width: 100%;
        justify-content: center;
    }

    .repo-landing__hero-actions {
        flex-direction: column;
    }

    .repo-landing__hero-preview,
    .repo-landing__preview-frame {
        min-height: 0;
        height: clamp(220px, 62vw, 340px);
    }

    .repo-landing__hero::before {
        inset: -18px -16px -12px -16px;
        background:
            radial-gradient(circle at 76% 14%, color-mix(in srgb, var(--node-color) 8%, transparent) 0%, transparent 30%),
            linear-gradient(180deg, color-mix(in srgb, var(--node-color) 3%, transparent) 0%, transparent 56%);
        -webkit-mask-image:
            linear-gradient(180deg, transparent 0%, #000 12%, #000 68%, transparent 100%),
            linear-gradient(90deg, transparent 0%, #000 7%, #000 93%, transparent 100%);
        mask-image:
            linear-gradient(180deg, transparent 0%, #000 12%, #000 68%, transparent 100%),
            linear-gradient(90deg, transparent 0%, #000 7%, #000 93%, transparent 100%);
    }

    .repo-landing__footer {
        justify-items: start;
    }

    .repo-landing__footer-links {
        justify-content: flex-start;
    }

    .repo-docs__content > .repo-landing__footer {
        grid-template-columns: 1fr;
    }
}

@media (prefers-reduced-motion: reduce) {
    .repo-landing__topbar,
    .repo-landing__hero,
    .repo-landing__hero-copy,
    .repo-landing__hero-preview,
    .repo-landing__proof-strip,
    .repo-landing__section,
    .repo-install__hero-copy,
    .repo-install__command-card,
    .repo-install__steps,
    .repo-landing__footer,
    .repo-landing__card,
    .gv-connection-indicator__light {
        animation: none !important;
    }
}
