glassbox 0.2.2 → 0.2.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- :root{--bg: #1e1e2e;--bg-surface: #252536;--bg-hover: #2d2d44;--bg-active: #363652;--text: #cdd6f4;--text-dim: #8888aa;--text-bright: #ffffff;--accent: #89b4fa;--accent-hover: #74a8fc;--green: #a6e3a1;--red: #f38ba8;--yellow: #f9e2af;--orange: #fab387;--blue: #89b4fa;--purple: #cba6f7;--teal: #94e2d5;--border: #363652;--diff-add-bg: rgba(166, 227, 161, 0.1);--diff-add-border: rgba(166, 227, 161, 0.3);--diff-remove-bg: rgba(243, 139, 168, 0.1);--diff-remove-border: rgba(243, 139, 168, 0.3);--diff-context-bg: transparent;--gutter-bg: #1a1a2e;--gutter-text: #555577;--sidebar-w: 300px;--radius: 6px;--font-mono: 'JetBrains Mono', 'Fira Code', 'Cascadia Code', monospace;--font-sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);height:100vh;overflow:hidden}.review-app{display:flex;height:100vh}.sidebar{width:var(--sidebar-w);min-width:200px;max-width:60vw;background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.sidebar-resize{width:4px;cursor:col-resize;background:rgba(0,0,0,0);flex-shrink:0;transition:background .15s}.sidebar-resize:hover,.sidebar-resize.dragging{background:var(--accent)}.sidebar-header{position:relative;padding:16px;border-bottom:1px solid var(--border)}.sidebar-header h2{font-size:16px;font-weight:600;color:var(--text-bright);padding-right:24px}.review-mode{font-size:12px;color:var(--text-dim);margin-top:4px;display:block}.file-filter{padding:8px 16px;border-bottom:1px solid var(--border)}.file-filter-input{width:100%;padding:5px 8px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-mono);font-size:12px;outline:none}.file-filter-input:focus{border-color:var(--accent)}.file-filter-input::placeholder{color:var(--text-dim)}.sidebar-footer{padding:16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px}.file-list{flex:1;overflow-y:auto;padding:8px 0}.file-item{display:flex;align-items:center;padding:6px 16px 6px 16px;cursor:pointer;font-size:13px;gap:8px;border-left:3px solid rgba(0,0,0,0);transition:background .1s}.file-item:hover{background:var(--bg-hover)}.file-item.active{background:var(--bg-active);border-left-color:var(--accent)}.file-item .status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.file-item .status-dot.pending{background:var(--text-dim)}.file-item .status-dot.reviewed{background:var(--green)}.file-item .status-dot.skipped{background:var(--yellow)}.file-item .file-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--font-mono);font-size:12px}.file-item .file-status{font-size:11px;font-weight:500;padding:1px 6px;border-radius:3px}.file-status.added{color:var(--green);background:rgba(166,227,161,.1)}.file-status.modified{color:var(--yellow);background:rgba(249,226,175,.1)}.file-status.deleted{color:var(--red);background:rgba(243,139,168,.1)}.file-status.renamed{color:var(--purple);background:rgba(203,166,247,.1)}.annotation-count{font-size:11px;color:var(--accent);background:rgba(137,180,250,.15);padding:0 5px;border-radius:8px;min-width:18px;text-align:center}.folder-header{display:flex;align-items:center;padding:4px 16px;font-size:12px;color:var(--text-dim);gap:4px;user-select:none}.folder-header.collapsible{cursor:pointer}.folder-header.collapsible:hover{color:var(--text)}.folder-header.collapsed+.folder-content{display:none}.folder-header.collapsed .folder-arrow{transform:rotate(-90deg)}.folder-arrow{width:12px;font-size:10px;flex-shrink:0;text-align:center;transition:transform .1s}.folder-arrow-spacer{width:12px;flex-shrink:0}.folder-name{font-family:var(--font-mono);font-size:12px}.stale-dot{width:6px;height:6px;border-radius:50%;background:var(--orange);flex-shrink:0}.progress-bar{height:3px;background:var(--border);border-radius:2px;overflow:hidden;margin:8px 16px}.progress-bar-fill{height:100%;background:var(--accent);transition:width .3s}.main-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.diff-container{flex:1;overflow:auto}.welcome-message{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;color:var(--text-dim);gap:8px}.welcome-message h3{color:var(--text)}.diff-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--bg-surface);border-bottom:1px solid var(--border)}.diff-header .file-path{font-family:var(--font-mono);font-size:13px;color:var(--text-bright)}.diff-header-actions{display:flex;gap:8px;align-items:center}.outline-bar{position:sticky;top:41px;z-index:9;background:var(--bg-surface);border-bottom:1px solid var(--border);min-height:28px}.outline-breadcrumb{display:flex;align-items:center;gap:4px;padding:4px 16px;cursor:pointer;font-size:12px;font-family:var(--font-mono);color:var(--text-dim);user-select:none}.outline-breadcrumb:hover{background:var(--bg-hover)}.outline-icon{font-size:14px;margin-right:4px;color:var(--text-dim)}.outline-separator{color:var(--text-dim);margin:0 2px}.outline-crumb{color:var(--text)}.outline-crumb.outline-kind-class{color:var(--yellow, #f9e2af)}.outline-crumb.outline-kind-function{color:var(--purple, #cba6f7)}.outline-crumb-empty{color:var(--text-dim);font-style:italic}.outline-dropdown{position:absolute;top:100%;left:0;right:0;z-index:100;background:var(--bg-surface);border:1px solid var(--border);border-top:none;box-shadow:0 4px 16px rgba(0,0,0,.3);max-height:320px;overflow-y:auto}.outline-item{display:flex;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-family:var(--font-mono);cursor:pointer;color:var(--text)}.outline-item:hover{background:var(--bg-hover)}.outline-item.outline-kind-class .outline-item-icon{color:var(--yellow, #f9e2af)}.outline-item.outline-kind-function .outline-item-icon{color:var(--purple, #cba6f7)}.outline-item-icon{font-size:10px;font-weight:bold;width:14px;height:14px;display:flex;align-items:center;justify-content:center;border-radius:2px;background:hsla(0,0%,100%,.05);flex-shrink:0}.outline-item-line{color:var(--text-dim);margin-left:auto;font-size:11px}.diff-table-split{width:100%;font-family:var(--font-mono);font-size:13px;line-height:20px}.diff-table-split .hunk-separator{grid-column:1/-1}.split-row{display:grid;grid-template-columns:1fr 1fr}.split-row .diff-line{display:flex;min-width:0;overflow:hidden}.split-row .diff-line.empty{background:var(--gutter-bg);min-height:20px}.split-row .gutter{width:50px;min-width:50px;padding:0 6px;text-align:right;color:var(--gutter-text);background:var(--gutter-bg);user-select:none;font-size:12px;flex-shrink:0}.split-left{border-right:1px solid var(--border)}.diff-line{display:flex;min-height:20px;border-bottom:1px solid rgba(54,54,82,.3);cursor:pointer}.diff-line:hover{filter:brightness(1.2)}.diff-line.add{background:var(--diff-add-bg)}.diff-line.remove{background:var(--diff-remove-bg)}.diff-line.context{background:var(--diff-context-bg)}.diff-line .gutter{width:60px;min-width:60px;padding:0 8px;text-align:right;color:var(--gutter-text);background:var(--gutter-bg);user-select:none;font-size:12px;display:flex;align-items:center;justify-content:flex-end}.diff-line .code{flex:1;padding:0 12px;white-space:pre;overflow-x:auto;tab-size:4;scrollbar-width:none}.diff-line .code::-webkit-scrollbar{height:0}.diff-line.add .code::before{content:"+";color:var(--green);margin-right:4px}.diff-line.remove .code::before{content:"-";color:var(--red);margin-right:4px}.diff-line.drag-over{outline:2px solid var(--accent);outline-offset:-2px}.diff-table-unified{width:100%;font-family:var(--font-mono);font-size:13px;line-height:20px}.diff-table-unified .diff-line{display:flex;min-width:0}.diff-table-unified .gutter-old,.diff-table-unified .gutter-new{width:50px;min-width:50px;padding:0 6px;text-align:right;color:var(--gutter-text);background:var(--gutter-bg);user-select:none;font-size:12px}.hunk-separator{padding:4px 16px;background:rgba(137,180,250,.05);color:var(--text-dim);font-size:12px;font-family:var(--font-mono);border-top:1px solid var(--border);border-bottom:1px solid var(--border);cursor:pointer}.hunk-separator:hover{background:rgba(137,180,250,.1)}.expand-controls{display:flex;gap:8px;padding:2px 16px;background:rgba(137,180,250,.05);border-bottom:1px solid var(--border)}.expand-btn{font-size:11px;color:var(--accent);background:none;border:none;cursor:pointer;padding:2px 6px;border-radius:3px}.expand-btn:hover{background:rgba(137,180,250,.15)}.expanded-context{background:rgba(137,180,250,.03)}.wrap-lines .code{white-space:pre-wrap !important;word-break:break-all;overflow-x:visible !important}.diff-toolbar{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;background:var(--bg-surface);border-top:1px solid var(--border);flex-shrink:0}.diff-toolbar-left,.diff-toolbar-right{display:flex;align-items:center;gap:8px}.segmented-control{display:flex;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.segment{padding:3px 12px;font-size:12px;background:none;border:none;color:var(--text-dim);cursor:pointer;transition:background .15s,color .15s;font-family:var(--font-sans)}.segment:hover{color:var(--text);background:var(--bg-hover)}.segment.active{background:var(--accent);color:var(--bg)}.segment+.segment{border-left:1px solid var(--border)}.toolbar-btn{padding:3px 10px;font-size:12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-dim);cursor:pointer;font-family:var(--font-sans);transition:background .15s,color .15s}.toolbar-btn:hover{color:var(--text);background:var(--bg-hover)}.toolbar-btn.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}.language-popup{position:fixed;z-index:1000;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px rgba(0,0,0,.4);width:200px;max-height:320px;display:flex;flex-direction:column}.language-filter{padding:6px 8px;background:var(--bg);color:var(--text);border:none;border-bottom:1px solid var(--border);font-family:var(--font-mono);font-size:12px;outline:none}.language-filter::placeholder{color:var(--text-dim)}.language-list{overflow-y:auto;max-height:280px}.language-option{padding:4px 10px;font-size:12px;cursor:pointer;color:var(--text);font-family:var(--font-mono)}.language-option:hover{background:var(--bg-hover)}.language-option.active{background:var(--bg-active);color:var(--accent)}.language-option.disabled{color:var(--text-dim);cursor:default;font-style:italic}.language-option.disabled:hover{background:none}.language-separator{height:1px;background:var(--border);margin:4px 0}.has-annotation .gutter{position:relative}.has-annotation .gutter::after{content:"";position:absolute;right:2px;top:50%;transform:translateY(-50%);width:6px;height:6px;border-radius:50%;background:var(--accent)}.annotation-row{padding:8px 16px 8px 76px;background:rgba(137,180,250,.05);border-left:3px solid var(--accent);font-family:var(--font-sans);font-size:13px}.annotation-row .annotation-item{display:flex;gap:8px;align-items:flex-start;padding:4px 0}.annotation-row:has(.annotation-stale){border-left-color:var(--orange);background:rgba(250,179,135,.05)}.annotation-category{font-size:11px;font-weight:600;padding:1px 6px;border-radius:3px;white-space:nowrap;flex-shrink:0}.annotation-category[data-action=reclassify]{cursor:pointer}.annotation-category[data-action=reclassify]:hover{filter:brightness(1.3)}.category-bug{color:var(--red);background:rgba(243,139,168,.15)}.category-fix{color:var(--orange);background:rgba(250,179,135,.15)}.category-style{color:var(--purple);background:rgba(203,166,247,.15)}.category-pattern-follow{color:var(--green);background:rgba(166,227,161,.15)}.category-pattern-avoid{color:var(--red);background:rgba(243,139,168,.15)}.category-note{color:var(--blue);background:rgba(137,180,250,.15)}.category-remember{color:var(--yellow);background:rgba(249,226,175,.15)}.annotation-text{flex:1;color:var(--text);line-height:1.4}.annotation-actions{display:flex;gap:4px;flex-shrink:0}.annotation-stale{opacity:.7}.btn-keep{color:var(--orange)}.btn-keep:hover{background:rgba(250,179,135,.15)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;padding:3px 4px}.btn-icon svg{display:block}.reclassify-popup{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:4px 0;box-shadow:0 4px 12px rgba(0,0,0,.3);min-width:140px}.reclassify-option{padding:6px 12px;cursor:pointer}.reclassify-option:hover{background:var(--bg-hover)}.reclassify-option.active{background:rgba(137,180,250,.1)}.annotation-drag-handle{cursor:grab;color:var(--text-dim);font-size:14px;line-height:1;flex-shrink:0;user-select:none;padding:0 2px}.annotation-drag-handle:hover{color:var(--text)}.annotation-form-container{padding:12px 16px 12px 76px;background:rgba(137,180,250,.08);border-left:3px solid var(--accent)}.annotation-form{display:flex;flex-direction:column;gap:8px}.annotation-form textarea{width:100%;min-height:60px;padding:8px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-sans);font-size:13px;resize:vertical}.annotation-form textarea:focus{outline:none;border-color:var(--accent)}.form-category-badge{cursor:pointer;align-self:flex-start}.form-category-badge:hover{filter:brightness(1.3)}.annotation-form-actions{display:flex;gap:8px;justify-content:flex-end}.btn{padding:6px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-surface);color:var(--text);cursor:pointer;font-size:13px;transition:background .15s}.btn:hover{background:var(--bg-hover)}.btn.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}.btn-sm{padding:3px 10px;font-size:12px}.btn-xs{padding:2px 6px;font-size:11px}.btn-primary{background:var(--accent);color:var(--bg);border-color:var(--accent);font-weight:600}.btn-primary:hover{background:var(--accent-hover)}.btn-danger{color:var(--red)}.btn-danger:hover{background:rgba(243,139,168,.15)}.btn-link{background:none;border:none;color:var(--accent);text-decoration:none;text-align:center}.btn-link:hover{text-decoration:underline}body:has(.history-page){overflow:auto}.history-page{max-width:800px;margin:0 auto;padding:40px 20px}.history-page h1{margin-bottom:24px}.history-item{padding:16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;position:relative}.history-item h3{font-size:15px;margin-bottom:4px;padding-right:32px}.history-item .meta{font-size:12px;color:var(--text-dim)}.history-item .delete-review-btn{position:absolute;top:12px;right:12px;background:none;border:none;color:var(--text-dim);cursor:pointer;padding:4px;border-radius:var(--radius);font-size:16px;line-height:1;opacity:0;transition:opacity .15s,color .15s}.history-item .delete-review-btn:hover{color:var(--red);background:rgba(243,139,168,.15)}.history-item:hover .delete-review-btn{opacity:1}.bulk-actions{display:flex;gap:8px;margin:12px 0;padding:4px 0;align-items:center}.bulk-actions span{font-size:13px;color:var(--text-dim);margin-right:auto}.status-badge{display:inline-block;font-size:11px;padding:1px 8px;border-radius:10px;font-weight:500}.status-badge.in_progress,.status-badge.in-progress{color:var(--yellow);background:rgba(249,226,175,.15)}.status-badge.completed{color:var(--green);background:rgba(166,227,161,.15)}.history-item-link{text-decoration:none;color:inherit;display:block}.history-item-link:hover .history-item{border-color:var(--accent);background:var(--bg-hover)}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:24px;max-width:480px;width:90%}.modal h3{margin-bottom:12px}.modal p{margin-bottom:16px;color:var(--text-dim);font-size:14px}.modal-label{margin-bottom:4px !important;font-size:13px !important;color:var(--text-dim) !important}.modal-copyable{font-family:var(--font-mono);font-size:12px;color:var(--accent);background:var(--bg);padding:8px 12px;border-radius:var(--radius);border:1px solid var(--border);margin-bottom:16px;cursor:pointer;position:relative;word-break:break-all;transition:border-color .15s}.modal-copyable:hover{border-color:var(--accent)}.modal-copyable.copied::after{content:"Copied!";position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:11px;color:var(--green);font-family:var(--font-sans)}.modal-gitignore{margin-bottom:16px;padding-top:12px;border-top:1px solid var(--border)}.modal-actions{display:flex;gap:8px;justify-content:flex-end}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:rgba(0,0,0,0)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.hljs-keyword,.hljs-selector-tag,.hljs-built_in,.hljs-name{color:var(--purple)}.hljs-string,.hljs-attr,.hljs-template-variable,.hljs-addition{color:var(--green)}.hljs-comment,.hljs-quote{color:var(--text-dim);font-style:italic}.hljs-number,.hljs-literal,.hljs-selector-id{color:var(--orange)}.hljs-type,.hljs-class .hljs-title,.hljs-title.class_,.hljs-title.function_{color:var(--yellow)}.hljs-variable,.hljs-template-variable{color:var(--red)}.hljs-regexp,.hljs-link{color:var(--teal)}.hljs-symbol,.hljs-bullet{color:var(--orange)}.hljs-meta,.hljs-meta .hljs-keyword{color:var(--blue)}.hljs-deletion{color:var(--red)}.hljs-section,.hljs-title{color:var(--blue);font-weight:600}.hljs-attribute{color:var(--yellow)}.hljs-tag{color:var(--red)}.hljs-tag .hljs-name{color:var(--red)}.hljs-tag .hljs-attr{color:var(--yellow)}.hljs-params{color:var(--text)}.hljs-property{color:var(--blue)}.hljs-punctuation{color:var(--text-dim)}.hljs-operator{color:var(--teal)}.hljs-subst{color:var(--text)}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.sort-mode-bar{display:flex;align-items:center;gap:8px;padding:6px 16px;border-bottom:1px solid var(--border)}.sort-mode-control{flex-shrink:0}.sort-mode-control .sort-segment{padding:3px 8px;display:inline-flex;align-items:center;justify-content:center}.sort-mode-control .sort-segment svg{display:block}.sort-risk-controls{display:flex;align-items:center;gap:4px;margin-left:auto}.sort-risk-toggle{font-size:11px;padding:2px 6px}.sort-dimension-select{font-size:11px;padding:2px 4px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-sans);cursor:pointer}.sort-dimension-select:focus{outline:none;border-color:var(--accent)}.risk-badge{font-size:11px;font-weight:600;font-family:var(--font-mono);padding:0 4px;border-radius:3px;cursor:pointer;flex-shrink:0;min-width:32px;text-align:center;background:hsla(0,0%,100%,.05)}.risk-badge:hover{background:hsla(0,0%,100%,.1)}.risk-critical{background:rgba(243,139,168,.15) !important}.risk-high{background:rgba(250,179,135,.15) !important}.risk-medium{background:rgba(249,226,175,.15) !important}.risk-low{background:rgba(166,227,161,.15) !important}.risk-popover{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px rgba(0,0,0,.4);padding:12px;min-width:240px;max-width:320px}.risk-popover-header{font-size:12px;font-weight:600;color:var(--text-bright);margin-bottom:8px}.risk-popover-dimensions{display:flex;flex-direction:column;gap:4px}.risk-dimension-row{display:flex;align-items:center;gap:8px;font-size:11px}.risk-dimension-label{width:90px;flex-shrink:0;color:var(--text-dim);text-transform:capitalize}.risk-dimension-bar-track{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.risk-dimension-bar-fill{height:100%;border-radius:2px;transition:width .3s}.risk-dimension-value{width:28px;text-align:right;font-family:var(--font-mono);font-size:10px;flex-shrink:0}.risk-popover-rationale{margin-top:8px;padding-top:8px;border-top:1px solid var(--border);font-size:12px;color:var(--text-dim);line-height:1.4}.narrative-position{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--text-dim);background:hsla(0,0%,100%,.05);border-radius:50%;flex-shrink:0}.file-path-dim{font-size:10px;color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:1;min-width:0;font-family:var(--font-mono)}.analysis-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 16px;color:var(--text-dim);font-size:13px}.analysis-loading-inline{display:flex;align-items:center;gap:8px;padding:8px 16px;color:var(--text-dim);font-size:12px;border-bottom:1px solid var(--border);background:hsla(0,0%,100%,.02)}.analysis-progress-info{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.analysis-progress-bar{height:3px;background:var(--border);border-radius:2px;overflow:hidden}.analysis-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.analysis-spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.analysis-spinner-sm{width:14px;height:14px;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.analysis-error{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;color:var(--red);font-size:12px;text-align:center;overflow-wrap:break-word;word-break:break-word;overflow:hidden;max-width:100%}.ai-note-overview{padding:8px 12px;font-size:12px;line-height:1.5;border-bottom:1px solid var(--border)}.ai-note-risk.ai-note-overview{background:rgba(243,139,168,.06)}.ai-note-risk.ai-note-row{background:rgba(243,139,168,.06)}.ai-note-narrative.ai-note-overview{background:rgba(137,180,250,.06)}.ai-note-narrative.ai-note-row{background:rgba(137,180,250,.06)}.ai-note-overview-content{display:flex;align-items:flex-start;gap:8px}.ai-note-label{font-size:10px;font-weight:600;text-transform:uppercase;padding:1px 5px;border-radius:3px;flex-shrink:0;letter-spacing:.5px}.ai-note-label-risk{color:var(--red);background:rgba(243,139,168,.15)}.ai-note-label-narrative{color:var(--blue, #89b4fa);background:rgba(137,180,250,.15)}.ai-note-guided.ai-note-overview{background:rgba(166,227,161,.06)}.ai-note-guided.ai-note-row{background:rgba(166,227,161,.06)}.ai-note-label-guided{color:var(--green, #a6e3a1);background:rgba(166,227,161,.15)}.ai-note-text{color:var(--text-dim)}.ai-note-row{padding:4px 12px 4px 60px;border-top:1px solid hsla(0,0%,100%,.03)}.ai-note-item{display:flex;align-items:flex-start;gap:8px;font-size:12px;line-height:1.4}.settings-dialog{max-width:460px}.settings-section{margin-bottom:16px}.settings-section-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.settings-heading{font-size:13px;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.04em}.settings-beta-badge{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--orange);background:color-mix(in srgb, var(--orange) 15%, transparent);padding:1px 5px;border-radius:3px;line-height:1.4}.settings-disclaimer{font-size:11px;color:var(--text-dim);margin-bottom:12px;line-height:1.4}.settings-divider{border:none;border-top:1px solid var(--border);margin:16px 0}.settings-label{display:block;font-size:12px;font-weight:600;color:var(--text-dim);margin-bottom:6px}.settings-label.settings-label-spaced{margin-top:12px}.settings-platform-control{width:100%}.settings-platform-control .segment{flex:1;text-align:center}.settings-select{width:100%;padding:6px 8px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-sans);font-size:13px;cursor:pointer}.settings-select:focus{outline:none;border-color:var(--accent)}.settings-input{width:100%;padding:6px 8px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-mono);font-size:12px;margin-top:8px}.settings-input:focus{outline:none;border-color:var(--accent)}.settings-input::placeholder{color:var(--text-dim)}.settings-key-status{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-dim)}.settings-key-status svg{flex-shrink:0}.settings-key-status.settings-key-configured{color:var(--green)}.settings-key-missing{color:var(--orange)}.settings-key-input-group{margin-top:4px}.settings-storage-options{display:flex;flex-direction:column;gap:4px;margin-top:8px}.settings-radio{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text);cursor:pointer}.settings-radio input[type=radio]{accent-color:var(--accent)}.settings-warning{font-size:11px;color:var(--orange);margin-top:4px;line-height:1.4}.settings-checkbox{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text);cursor:pointer}.settings-checkbox input[type=checkbox]{accent-color:var(--accent)}.settings-guided-topics{margin-bottom:16px}.settings-tags{display:flex;flex-wrap:wrap;gap:6px}.settings-tag{font-size:12px;padding:3px 10px;border-radius:12px;border:1px solid var(--border);background:rgba(0,0,0,0);color:var(--text-dim);cursor:pointer;transition:all .15s ease;font-family:var(--font-sans)}.settings-tag:hover{border-color:var(--accent);color:var(--text)}.settings-tag.active{background:color-mix(in srgb, var(--accent) 20%, transparent);border-color:var(--accent);color:var(--accent);font-weight:500}.settings-more-toggle{display:block;margin-top:8px;padding:0;border:none;background:none;color:var(--accent);font-size:11px;cursor:pointer;font-family:var(--font-sans)}.settings-more-toggle:hover{text-decoration:underline}.settings-tags-more{margin-top:8px}.settings-gear{position:absolute;top:12px;right:12px;padding:4px;color:var(--text-dim);background:none;border:none;cursor:pointer;border-radius:var(--radius);display:flex;align-items:center;justify-content:center}.settings-gear:hover{color:var(--text);background:var(--bg-hover)}.settings-gear svg{display:block}
1
+ :root{--bg: #1e1e2e;--bg-surface: #252536;--bg-hover: #2d2d44;--bg-active: #363652;--text: #cdd6f4;--text-dim: #8888aa;--text-bright: #ffffff;--accent: #89b4fa;--accent-hover: #74a8fc;--green: #a6e3a1;--red: #f38ba8;--yellow: #f9e2af;--orange: #fab387;--blue: #89b4fa;--purple: #cba6f7;--teal: #94e2d5;--border: #363652;--diff-add-bg: rgba(166, 227, 161, 0.1);--diff-add-border: rgba(166, 227, 161, 0.3);--diff-remove-bg: rgba(243, 139, 168, 0.1);--diff-remove-border: rgba(243, 139, 168, 0.3);--diff-context-bg: transparent;--gutter-bg: #1a1a2e;--gutter-text: #555577;--sidebar-w: 300px;--radius: 6px;--font-mono: 'JetBrains Mono', 'Fira Code', 'Cascadia Code', monospace;--font-sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);height:100vh;overflow:hidden}.review-app{display:flex;height:100vh}.sidebar{width:var(--sidebar-w);min-width:200px;max-width:60vw;background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.sidebar-resize{width:4px;cursor:col-resize;background:rgba(0,0,0,0);flex-shrink:0;transition:background .15s}.sidebar-resize:hover,.sidebar-resize.dragging{background:var(--accent)}.sidebar-header{position:relative;padding:16px;border-bottom:1px solid var(--border)}.sidebar-header h2{font-size:16px;font-weight:600;color:var(--text-bright);padding-right:24px}.review-mode{font-size:12px;color:var(--text-dim);margin-top:4px;display:block}.file-filter{padding:8px 16px;border-bottom:1px solid var(--border)}.file-filter-input{width:100%;padding:5px 8px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-mono);font-size:12px;outline:none}.file-filter-input:focus{border-color:var(--accent)}.file-filter-input::placeholder{color:var(--text-dim)}.sidebar-footer{padding:16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px}.file-list{flex:1;overflow-y:auto;padding:8px 0}.file-item{display:flex;align-items:center;padding:6px 16px 6px 16px;cursor:pointer;font-size:13px;gap:8px;border-left:3px solid rgba(0,0,0,0);transition:background .1s}.file-item:hover{background:var(--bg-hover)}.file-item.active{background:var(--bg-active);border-left-color:var(--accent)}.file-item .status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.file-item .status-dot.pending{background:var(--text-dim)}.file-item .status-dot.reviewed{background:var(--green)}.file-item .status-dot.skipped{background:var(--yellow)}.file-item .file-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--font-mono);font-size:12px}.file-item .file-status{font-size:11px;font-weight:500;padding:1px 6px;border-radius:3px}.file-status.added{color:var(--green);background:rgba(166,227,161,.1)}.file-status.modified{color:var(--yellow);background:rgba(249,226,175,.1)}.file-status.deleted{color:var(--red);background:rgba(243,139,168,.1)}.file-status.renamed{color:var(--purple);background:rgba(203,166,247,.1)}.annotation-count{font-size:11px;color:var(--accent);background:rgba(137,180,250,.15);padding:0 5px;border-radius:8px;min-width:18px;text-align:center}.folder-header{display:flex;align-items:center;padding:4px 16px;font-size:12px;color:var(--text-dim);gap:4px;user-select:none}.folder-header.collapsible{cursor:pointer}.folder-header.collapsible:hover{color:var(--text)}.folder-header.collapsed+.folder-content{display:none}.folder-header.collapsed .folder-arrow{transform:rotate(-90deg)}.folder-arrow{width:12px;font-size:10px;flex-shrink:0;text-align:center;transition:transform .1s}.folder-arrow-spacer{width:12px;flex-shrink:0}.folder-name{font-family:var(--font-mono);font-size:12px}.stale-dot{width:6px;height:6px;border-radius:50%;background:var(--orange);flex-shrink:0}.progress-bar{height:3px;background:var(--border);border-radius:2px;overflow:hidden;margin:8px 16px}.progress-bar-fill{height:100%;background:var(--accent);transition:width .3s}.main-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.diff-container{flex:1;overflow:auto}.welcome-message{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;color:var(--text-dim);gap:8px}.welcome-message h3{color:var(--text)}.diff-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--bg-surface);border-bottom:1px solid var(--border)}.diff-header .file-path{font-family:var(--font-mono);font-size:13px;color:var(--text-bright)}.diff-header-actions{display:flex;gap:8px;align-items:center}.outline-bar{position:sticky;top:41px;z-index:9;background:var(--bg-surface);border-bottom:1px solid var(--border);min-height:28px}.outline-breadcrumb{display:flex;align-items:center;gap:4px;padding:4px 16px;cursor:pointer;font-size:12px;font-family:var(--font-mono);color:var(--text-dim);user-select:none}.outline-breadcrumb:hover{background:var(--bg-hover)}.outline-icon{font-size:14px;margin-right:4px;color:var(--text-dim)}.outline-separator{color:var(--text-dim);margin:0 2px}.outline-crumb{color:var(--text)}.outline-crumb.outline-kind-class{color:var(--yellow, #f9e2af)}.outline-crumb.outline-kind-function{color:var(--purple, #cba6f7)}.outline-crumb-empty{color:var(--text-dim);font-style:italic}.outline-dropdown{position:absolute;top:100%;left:0;right:0;z-index:100;background:var(--bg-surface);border:1px solid var(--border);border-top:none;box-shadow:0 4px 16px rgba(0,0,0,.3);max-height:320px;overflow-y:auto}.outline-item{display:flex;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-family:var(--font-mono);cursor:pointer;color:var(--text)}.outline-item:hover{background:var(--bg-hover)}.outline-item.outline-kind-class .outline-item-icon{color:var(--yellow, #f9e2af)}.outline-item.outline-kind-function .outline-item-icon{color:var(--purple, #cba6f7)}.outline-item-icon{font-size:10px;font-weight:bold;width:14px;height:14px;display:flex;align-items:center;justify-content:center;border-radius:2px;background:hsla(0,0%,100%,.05);flex-shrink:0}.outline-item-line{color:var(--text-dim);margin-left:auto;font-size:11px}.diff-table-split{width:100%;font-family:var(--font-mono);font-size:13px;line-height:20px}.diff-table-split .hunk-separator{grid-column:1/-1}.split-row{display:grid;grid-template-columns:1fr 1fr}.split-row .diff-line{display:flex;min-width:0;overflow:hidden}.split-row .diff-line.empty{background:var(--gutter-bg);min-height:20px}.split-row .gutter{width:50px;min-width:50px;padding:0 6px;text-align:right;color:var(--gutter-text);background:var(--gutter-bg);user-select:none;font-size:12px;flex-shrink:0}.split-left{border-right:1px solid var(--border)}.diff-line{display:flex;min-height:20px;border-bottom:1px solid rgba(54,54,82,.3);cursor:pointer}.diff-line:hover{filter:brightness(1.2)}.diff-line.add{background:var(--diff-add-bg)}.diff-line.remove{background:var(--diff-remove-bg)}.diff-line.context{background:var(--diff-context-bg)}.diff-line .gutter{width:60px;min-width:60px;padding:0 8px;text-align:right;color:var(--gutter-text);background:var(--gutter-bg);user-select:none;font-size:12px;display:flex;align-items:center;justify-content:flex-end}.diff-line .code{flex:1;padding:0 12px;white-space:pre;overflow-x:auto;tab-size:4;scrollbar-width:none}.diff-line .code::-webkit-scrollbar{height:0}.diff-line.add .code::before{content:"+";color:var(--green);margin-right:4px}.diff-line.remove .code::before{content:"-";color:var(--red);margin-right:4px}.diff-line.drag-over{outline:2px solid var(--accent);outline-offset:-2px}.diff-table-unified{width:100%;font-family:var(--font-mono);font-size:13px;line-height:20px}.diff-table-unified .diff-line{display:flex;min-width:0}.diff-table-unified .gutter-old,.diff-table-unified .gutter-new{width:50px;min-width:50px;padding:0 6px;text-align:right;color:var(--gutter-text);background:var(--gutter-bg);user-select:none;font-size:12px}.hunk-separator{padding:4px 16px;background:rgba(137,180,250,.05);color:var(--text-dim);font-size:12px;font-family:var(--font-mono);border-top:1px solid var(--border);border-bottom:1px solid var(--border);cursor:pointer}.hunk-separator:hover{background:rgba(137,180,250,.1)}.expand-controls{display:flex;gap:8px;padding:2px 16px;background:rgba(137,180,250,.05);border-bottom:1px solid var(--border)}.expand-btn{font-size:11px;color:var(--accent);background:none;border:none;cursor:pointer;padding:2px 6px;border-radius:3px}.expand-btn:hover{background:rgba(137,180,250,.15)}.expanded-context{background:rgba(137,180,250,.03)}.wrap-lines .code{white-space:pre-wrap !important;word-break:break-all;overflow-x:visible !important}.diff-toolbar{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;background:var(--bg-surface);border-top:1px solid var(--border);flex-shrink:0}.diff-toolbar-left,.diff-toolbar-right{display:flex;align-items:center;gap:8px}.segmented-control{display:flex;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.segment{padding:3px 12px;font-size:12px;background:none;border:none;color:var(--text-dim);cursor:pointer;transition:background .15s,color .15s;font-family:var(--font-sans)}.segment:hover{color:var(--text);background:var(--bg-hover)}.segment.active{background:var(--accent);color:var(--bg)}.segment+.segment{border-left:1px solid var(--border)}.toolbar-btn{padding:3px 10px;font-size:12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-dim);cursor:pointer;font-family:var(--font-sans);transition:background .15s,color .15s}.toolbar-btn:hover{color:var(--text);background:var(--bg-hover)}.toolbar-btn.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}.language-popup{position:fixed;z-index:1000;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px rgba(0,0,0,.4);width:200px;max-height:320px;display:flex;flex-direction:column}.language-filter{padding:6px 8px;background:var(--bg);color:var(--text);border:none;border-bottom:1px solid var(--border);font-family:var(--font-mono);font-size:12px;outline:none}.language-filter::placeholder{color:var(--text-dim)}.language-list{overflow-y:auto;max-height:280px}.language-option{padding:4px 10px;font-size:12px;cursor:pointer;color:var(--text);font-family:var(--font-mono)}.language-option:hover{background:var(--bg-hover)}.language-option.active{background:var(--bg-active);color:var(--accent)}.language-option.disabled{color:var(--text-dim);cursor:default;font-style:italic}.language-option.disabled:hover{background:none}.language-separator{height:1px;background:var(--border);margin:4px 0}.has-annotation .gutter{position:relative}.has-annotation .gutter::after{content:"";position:absolute;right:2px;top:50%;transform:translateY(-50%);width:6px;height:6px;border-radius:50%;background:var(--accent)}.annotation-row{padding:8px 16px 8px 76px;background:rgba(137,180,250,.05);border-left:3px solid var(--accent);font-family:var(--font-sans);font-size:13px}.annotation-row .annotation-item{display:flex;gap:8px;align-items:flex-start;padding:4px 0}.annotation-row:has(.annotation-stale){border-left-color:var(--orange);background:rgba(250,179,135,.05)}.annotation-category{font-size:11px;font-weight:600;padding:1px 6px;border-radius:3px;white-space:nowrap;flex-shrink:0}.annotation-category[data-action=reclassify]{cursor:pointer}.annotation-category[data-action=reclassify]:hover{filter:brightness(1.3)}.category-bug{color:var(--red);background:rgba(243,139,168,.15)}.category-fix{color:var(--orange);background:rgba(250,179,135,.15)}.category-style{color:var(--purple);background:rgba(203,166,247,.15)}.category-pattern-follow{color:var(--green);background:rgba(166,227,161,.15)}.category-pattern-avoid{color:var(--red);background:rgba(243,139,168,.15)}.category-note{color:var(--blue);background:rgba(137,180,250,.15)}.category-remember{color:var(--yellow);background:rgba(249,226,175,.15)}.annotation-text{flex:1;color:var(--text);line-height:1.4}.annotation-actions{display:flex;gap:4px;flex-shrink:0}.annotation-stale{opacity:.7}.btn-keep{color:var(--orange)}.btn-keep:hover{background:rgba(250,179,135,.15)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;padding:3px 4px}.btn-icon svg{display:block}.reclassify-popup{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:4px 0;box-shadow:0 4px 12px rgba(0,0,0,.3);min-width:140px}.reclassify-option{padding:6px 12px;cursor:pointer}.reclassify-option:hover{background:var(--bg-hover)}.reclassify-option.active{background:rgba(137,180,250,.1)}.annotation-drag-handle{cursor:grab;color:var(--text-dim);font-size:14px;line-height:1;flex-shrink:0;user-select:none;padding:0 2px}.annotation-drag-handle:hover{color:var(--text)}.annotation-form-container{padding:12px 16px 12px 76px;background:rgba(137,180,250,.08);border-left:3px solid var(--accent)}.annotation-form{display:flex;flex-direction:column;gap:8px}.annotation-form textarea{width:100%;min-height:60px;padding:8px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-sans);font-size:13px;resize:vertical}.annotation-form textarea:focus{outline:none;border-color:var(--accent)}.form-category-badge{cursor:pointer;align-self:flex-start}.form-category-badge:hover{filter:brightness(1.3)}.annotation-form-actions{display:flex;gap:8px;justify-content:flex-end}.btn{padding:6px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-surface);color:var(--text);cursor:pointer;font-size:13px;transition:background .15s}.btn:hover{background:var(--bg-hover)}.btn.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}.btn-sm{padding:3px 10px;font-size:12px}.btn-xs{padding:2px 6px;font-size:11px}.btn-primary{background:var(--accent);color:var(--bg);border-color:var(--accent);font-weight:600}.btn-primary:hover{background:var(--accent-hover)}.btn-danger{color:var(--red)}.btn-danger:hover{background:rgba(243,139,168,.15)}.btn-link{background:none;border:none;color:var(--accent);text-decoration:none;text-align:center}.btn-link:hover{text-decoration:underline}body:has(.history-page){overflow:auto}.history-page{max-width:800px;margin:0 auto;padding:40px 20px}.history-page h1{margin-bottom:24px}.history-item{padding:16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;position:relative}.history-item h3{font-size:15px;margin-bottom:4px;padding-right:32px}.history-item .meta{font-size:12px;color:var(--text-dim)}.history-item .delete-review-btn{position:absolute;top:12px;right:12px;background:none;border:none;color:var(--text-dim);cursor:pointer;padding:4px;border-radius:var(--radius);font-size:16px;line-height:1;opacity:0;transition:opacity .15s,color .15s}.history-item .delete-review-btn:hover{color:var(--red);background:rgba(243,139,168,.15)}.history-item:hover .delete-review-btn{opacity:1}.bulk-actions{display:flex;gap:8px;margin:12px 0;padding:4px 0;align-items:center}.bulk-actions span{font-size:13px;color:var(--text-dim);margin-right:auto}.status-badge{display:inline-block;font-size:11px;padding:1px 8px;border-radius:10px;font-weight:500}.status-badge.in_progress,.status-badge.in-progress{color:var(--yellow);background:rgba(249,226,175,.15)}.status-badge.completed{color:var(--green);background:rgba(166,227,161,.15)}.history-item-link{text-decoration:none;color:inherit;display:block}.history-item-link:hover .history-item{border-color:var(--accent);background:var(--bg-hover)}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:24px;max-width:480px;width:90%}.modal h3{margin-bottom:12px}.modal p{margin-bottom:16px;color:var(--text-dim);font-size:14px}.modal-label{margin-bottom:4px !important;font-size:13px !important;color:var(--text-dim) !important}.modal-copyable{font-family:var(--font-mono);font-size:12px;color:var(--accent);background:var(--bg);padding:8px 12px;border-radius:var(--radius);border:1px solid var(--border);margin-bottom:16px;cursor:pointer;position:relative;word-break:break-all;transition:border-color .15s}.modal-copyable:hover{border-color:var(--accent)}.modal-copyable.copied::after{content:"Copied!";position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:11px;color:var(--green);font-family:var(--font-sans)}.modal-gitignore{margin-bottom:16px;padding-top:12px;border-top:1px solid var(--border)}.modal-actions{display:flex;gap:8px;justify-content:flex-end}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:rgba(0,0,0,0)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.hljs-keyword,.hljs-selector-tag,.hljs-built_in,.hljs-name{color:var(--purple)}.hljs-string,.hljs-attr,.hljs-template-variable,.hljs-addition{color:var(--green)}.hljs-comment,.hljs-quote{color:var(--text-dim);font-style:italic}.hljs-number,.hljs-literal,.hljs-selector-id{color:var(--orange)}.hljs-type,.hljs-class .hljs-title,.hljs-title.class_,.hljs-title.function_{color:var(--yellow)}.hljs-variable,.hljs-template-variable{color:var(--red)}.hljs-regexp,.hljs-link{color:var(--teal)}.hljs-symbol,.hljs-bullet{color:var(--orange)}.hljs-meta,.hljs-meta .hljs-keyword{color:var(--blue)}.hljs-deletion{color:var(--red)}.hljs-section,.hljs-title{color:var(--blue);font-weight:600}.hljs-attribute{color:var(--yellow)}.hljs-tag{color:var(--red)}.hljs-tag .hljs-name{color:var(--red)}.hljs-tag .hljs-attr{color:var(--yellow)}.hljs-params{color:var(--text)}.hljs-property{color:var(--blue)}.hljs-punctuation{color:var(--text-dim)}.hljs-operator{color:var(--teal)}.hljs-subst{color:var(--text)}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.sort-mode-bar{display:flex;align-items:center;gap:8px;padding:6px 16px;border-bottom:1px solid var(--border)}.sort-mode-control{flex-shrink:0}.sort-mode-control .sort-segment{padding:3px 8px;display:inline-flex;align-items:center;justify-content:center}.sort-mode-control .sort-segment svg{display:block}.sort-risk-controls{display:flex;align-items:center;gap:4px;margin-left:auto}.sort-risk-toggle{font-size:11px;padding:2px 6px}.sort-dimension-select{font-size:11px;padding:2px 4px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-sans);cursor:pointer}.sort-dimension-select:focus{outline:none;border-color:var(--accent)}.risk-badge{font-size:11px;font-weight:600;font-family:var(--font-mono);padding:0 4px;border-radius:3px;cursor:pointer;flex-shrink:0;min-width:32px;text-align:center;background:hsla(0,0%,100%,.05)}.risk-badge:hover{background:hsla(0,0%,100%,.1)}.risk-critical{background:rgba(243,139,168,.15) !important}.risk-high{background:rgba(250,179,135,.15) !important}.risk-medium{background:rgba(249,226,175,.15) !important}.risk-low{background:rgba(166,227,161,.15) !important}.risk-popover{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px rgba(0,0,0,.4);padding:12px;min-width:240px;max-width:320px}.risk-popover-header{font-size:12px;font-weight:600;color:var(--text-bright);margin-bottom:8px}.risk-popover-dimensions{display:flex;flex-direction:column;gap:4px}.risk-dimension-row{display:flex;align-items:center;gap:8px;font-size:11px}.risk-dimension-label{width:90px;flex-shrink:0;color:var(--text-dim);text-transform:capitalize}.risk-dimension-bar-track{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.risk-dimension-bar-fill{height:100%;border-radius:2px;transition:width .3s}.risk-dimension-value{width:28px;text-align:right;font-family:var(--font-mono);font-size:10px;flex-shrink:0}.risk-popover-rationale{margin-top:8px;padding-top:8px;border-top:1px solid var(--border);font-size:12px;color:var(--text-dim);line-height:1.4}.narrative-position{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--text-dim);background:hsla(0,0%,100%,.05);border-radius:50%;flex-shrink:0}.file-path-dim{font-size:10px;color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:1;min-width:0;font-family:var(--font-mono)}.analysis-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 16px;color:var(--text-dim);font-size:13px}.analysis-loading-inline{display:flex;align-items:center;gap:8px;padding:8px 16px;color:var(--text-dim);font-size:12px;border-bottom:1px solid var(--border);background:hsla(0,0%,100%,.02)}.analysis-progress-info{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.analysis-progress-bar{height:3px;background:var(--border);border-radius:2px;overflow:hidden}.analysis-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.analysis-spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.analysis-spinner-sm{width:14px;height:14px;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.analysis-error{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;color:var(--red);font-size:12px;text-align:center;overflow-wrap:break-word;word-break:break-word;overflow:hidden;max-width:100%}.ai-note-overview{padding:8px 12px;font-size:12px;line-height:1.5;border-bottom:1px solid var(--border)}.ai-note-risk.ai-note-overview{background:rgba(243,139,168,.06)}.ai-note-risk.ai-note-row{background:rgba(243,139,168,.06)}.ai-note-narrative.ai-note-overview{background:rgba(137,180,250,.06)}.ai-note-narrative.ai-note-row{background:rgba(137,180,250,.06)}.ai-note-overview-content{display:flex;align-items:flex-start;gap:8px}.ai-note-label{font-size:10px;font-weight:600;text-transform:uppercase;padding:1px 5px;border-radius:3px;flex-shrink:0;letter-spacing:.5px}.ai-note-label-risk{color:var(--red);background:rgba(243,139,168,.15)}.ai-note-label-narrative{color:var(--blue, #89b4fa);background:rgba(137,180,250,.15)}.ai-note-guided.ai-note-overview{background:rgba(166,227,161,.06)}.ai-note-guided.ai-note-row{background:rgba(166,227,161,.06)}.ai-note-label-guided{color:var(--green, #a6e3a1);background:rgba(166,227,161,.15)}.ai-note-text{color:var(--text-dim)}.ai-note-row{padding:4px 12px 4px 60px;border-top:1px solid hsla(0,0%,100%,.03)}.ai-note-item{display:flex;align-items:flex-start;gap:8px;font-size:12px;line-height:1.4}.settings-dialog{max-width:460px}.settings-section{margin-bottom:16px}.settings-section-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.settings-heading{font-size:13px;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.04em}.settings-beta-badge{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--orange);background:color-mix(in srgb, var(--orange) 15%, transparent);padding:1px 5px;border-radius:3px;line-height:1.4}.settings-disclaimer{font-size:11px;color:var(--text-dim);margin-bottom:12px;line-height:1.4}.settings-hint{font-size:11px;color:var(--text-dim);margin-top:4px;line-height:1.4}.settings-divider{border:none;border-top:1px solid var(--border);margin:16px 0}.settings-label{display:block;font-size:12px;font-weight:600;color:var(--text-dim);margin-bottom:6px}.settings-label.settings-label-spaced{margin-top:12px}.settings-platform-control{width:100%}.settings-platform-control .segment{flex:1;text-align:center}.settings-select{width:100%;padding:6px 8px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-sans);font-size:13px;cursor:pointer}.settings-select:focus{outline:none;border-color:var(--accent)}.settings-input{width:100%;padding:6px 8px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-mono);font-size:12px;margin-top:8px}.settings-input:focus{outline:none;border-color:var(--accent)}.settings-input::placeholder{color:var(--text-dim)}.settings-key-status{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-dim)}.settings-key-status svg{flex-shrink:0}.settings-key-status.settings-key-configured{color:var(--green)}.settings-key-missing{color:var(--orange)}.settings-key-input-group{margin-top:4px}.settings-storage-options{display:flex;flex-direction:column;gap:4px;margin-top:8px}.settings-radio{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text);cursor:pointer}.settings-radio input[type=radio]{accent-color:var(--accent)}.settings-warning{font-size:11px;color:var(--orange);margin-top:4px;line-height:1.4}.settings-checkbox{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text);cursor:pointer}.settings-checkbox input[type=checkbox]{accent-color:var(--accent)}.settings-guided-topics{margin-bottom:16px}.settings-tags{display:flex;flex-wrap:wrap;gap:6px}.settings-tag{font-size:12px;padding:3px 10px;border-radius:12px;border:1px solid var(--border);background:rgba(0,0,0,0);color:var(--text-dim);cursor:pointer;transition:all .15s ease;font-family:var(--font-sans)}.settings-tag:hover{border-color:var(--accent);color:var(--text)}.settings-tag.active{background:color-mix(in srgb, var(--accent) 20%, transparent);border-color:var(--accent);color:var(--accent);font-weight:500}.settings-more-toggle{display:block;margin-top:8px;padding:0;border:none;background:none;color:var(--accent);font-size:11px;cursor:pointer;font-family:var(--font-sans)}.settings-more-toggle:hover{text-decoration:underline}.settings-tags-more{margin-top:8px}.settings-gear{position:absolute;top:12px;right:12px;padding:4px;color:var(--text-dim);background:none;border:none;cursor:pointer;border-radius:var(--radius);display:flex;align-items:center;justify-content:center}.settings-gear:hover{color:var(--text);background:var(--bg-hover)}.settings-gear svg{display:block}.update-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 20px;background:#dcfce7;border-bottom:2px solid #22c55e;font-size:13px;color:#166534;flex-shrink:0}@media(prefers-color-scheme: dark){.update-banner{background:#14532d;border-bottom-color:#22c55e;color:#86efac}}.update-banner-actions{display:flex;gap:8px;flex-shrink:0}.btn-accent{color:#fff;background:#22c55e;border-color:#22c55e}.btn-accent:hover:not(:disabled){background:#16a34a}.btn-accent:disabled{opacity:.7;cursor:default}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "glassbox",
3
- "version": "0.2.2",
3
+ "version": "0.2.4",
4
4
  "description": "A local code review tool for AI-generated code. Review diffs, annotate lines, and export structured feedback that AI tools can act on.",
5
5
  "type": "module",
6
6
  "license": "MIT",
@@ -33,6 +33,7 @@
33
33
  "build:client": "mkdir -p dist/client && npx esbuild src/client/app.ts --bundle --format=iife --outfile=dist/client/app.global.js --target=es2020 --jsx=automatic --jsx-import-source=#jsx --alias:#jsx/jsx-runtime=./src/jsx-runtime.ts && npx sass src/client/styles.scss dist/client/styles.css --style compressed --no-source-map",
34
34
  "dev:server": "npm run build:client && tsx --tsconfig tsconfig.json src/cli.ts --no-open --strict-port",
35
35
  "tauri": "tauri",
36
+ "tauri:clean": "rm -rf src-tauri/target",
36
37
  "tauri:dev": "bash scripts/ensure-sidecar-stub.sh && tauri dev",
37
38
  "tauri:build": "bash scripts/build-sidecar.sh && tauri build",
38
39
  "lint": "eslint src/",