:root{--diff-background-color:initial;--diff-text-color:initial;--diff-font-family:Consolas,Courier,monospace;--diff-selection-background-color:#b3d7ff;--diff-selection-text-color:var(--diff-text-color);--diff-gutter-insert-background-color:#d6fedb;--diff-gutter-insert-text-color:var(--diff-text-color);--diff-gutter-delete-background-color:#fadde0;--diff-gutter-delete-text-color:var(--diff-text-color);--diff-gutter-selected-background-color:#fffce0;--diff-gutter-selected-text-color:var(--diff-text-color);--diff-code-insert-background-color:#eaffee;--diff-code-insert-text-color:var(--diff-text-color);--diff-code-delete-background-color:#fdeff0;--diff-code-delete-text-color:var(--diff-text-color);--diff-code-insert-edit-background-color:#c0dc91;--diff-code-insert-edit-text-color:var(--diff-text-color);--diff-code-delete-edit-background-color:#f39ea2;--diff-code-delete-edit-text-color:var(--diff-text-color);--diff-code-selected-background-color:#fffce0;--diff-code-selected-text-color:var(--diff-text-color);--diff-omit-gutter-line-color:#cb2a1d}.diff{background-color:var(--diff-background-color);border-collapse:collapse;color:var(--diff-text-color);table-layout:fixed;width:100%}.diff::-moz-selection{background-color:#b3d7ff;background-color:var(--diff-selection-background-color);color:var(--diff-text-color);color:var(--diff-selection-text-color)}.diff::selection{background-color:#b3d7ff;background-color:var(--diff-selection-background-color);color:var(--diff-text-color);color:var(--diff-selection-text-color)}.diff td{padding-bottom:0;padding-top:0;vertical-align:top}.diff-line{font-family:Consolas,Courier,monospace;font-family:var(--diff-font-family);line-height:1.5}.diff-gutter>a{color:inherit;display:block}.diff-gutter{cursor:pointer;padding:0 1ch;text-align:right;-webkit-user-select:none;-moz-user-select:none;user-select:none}.diff-gutter-insert{background-color:#d6fedb;background-color:var(--diff-gutter-insert-background-color);color:var(--diff-text-color);color:var(--diff-gutter-insert-text-color)}.diff-gutter-delete{background-color:#fadde0;background-color:var(--diff-gutter-delete-background-color);color:var(--diff-text-color);color:var(--diff-gutter-delete-text-color)}.diff-gutter-omit{cursor:default}.diff-gutter-selected{background-color:#fffce0;background-color:var(--diff-gutter-selected-background-color);color:var(--diff-text-color);color:var(--diff-gutter-selected-text-color)}.diff-code{word-wrap:break-word;padding:0 0 0 .5em;white-space:pre-wrap;word-break:break-all}.diff-code-edit{color:inherit}.diff-code-insert{background-color:#eaffee;background-color:var(--diff-code-insert-background-color);color:var(--diff-text-color);color:var(--diff-code-insert-text-color)}.diff-code-insert .diff-code-edit{background-color:#c0dc91;background-color:var(--diff-code-insert-edit-background-color);color:var(--diff-text-color);color:var(--diff-code-insert-edit-text-color)}.diff-code-delete{background-color:#fdeff0;background-color:var(--diff-code-delete-background-color);color:var(--diff-text-color);color:var(--diff-code-delete-text-color)}.diff-code-delete .diff-code-edit{background-color:#f39ea2;background-color:var(--diff-code-delete-edit-background-color);color:var(--diff-text-color);color:var(--diff-code-delete-edit-text-color)}.diff-code-selected{background-color:#fffce0;background-color:var(--diff-code-selected-background-color);color:var(--diff-text-color);color:var(--diff-code-selected-text-color)}.diff-widget-content{vertical-align:top}.diff-gutter-col{width:7ch}.diff-gutter-omit{height:0}.diff-gutter-omit:before{background-color:#cb2a1d;background-color:var(--diff-omit-gutter-line-color);content:" ";display:block;height:100%;margin-left:4.6ch;overflow:hidden;white-space:pre;width:2px}.diff-decoration{line-height:1.5;-webkit-user-select:none;-moz-user-select:none;user-select:none}.diff-decoration-content{font-family:Consolas,Courier,monospace;font-family:var(--diff-font-family);padding:0}:root{color-scheme:dark;font-family:Inter,SF Pro Text,system-ui,sans-serif;background-color:#0f1115;color:#e6e6e6}*{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at top,#1b2234,#0f1115 55%,#0b0e14);overflow:hidden}#root,.app{height:100dvh;width:100dvw}.app{display:flex;align-items:stretch;justify-content:center}.app--startup{padding:24px}.startup{width:min(640px,100%);margin:0 auto;padding:32px 24px;background:#171a21b8;border:1px solid rgba(255,255,255,.08);border-radius:20px;backdrop-filter:blur(18px) saturate(120%);-webkit-backdrop-filter:blur(18px) saturate(120%);box-shadow:0 24px 48px #00000059}.startup__header h1{margin:0 0 8px;font-size:28px}.startup__header p{margin:0 0 24px;color:#a2a9b5}.tabs{display:flex;gap:8px;margin-bottom:16px}.tab{flex:1;padding:12px 16px;background:#20253099;border:1px solid rgba(255,255,255,.06);color:#c9cfda;border-radius:12px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:8px}.tab--active{background:#394256bf;border-color:#8797c880;color:#fff}.tab-panel{margin-bottom:16px}.upload-panel,.paste-panel{display:flex;flex-direction:column;gap:16px}textarea{min-height:220px;max-height:320px;resize:none;background:#0f1115b8;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px;color:#dfe3eb;font-family:SF Mono,Fira Code,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace}input[type=file]{background:#0f1115b8;border:1px dashed rgba(255,255,255,.1);border-radius:12px;padding:16px;color:#dfe3eb}button{font-family:inherit;cursor:pointer}.primary{background:#5d7cfa;color:#0f1115;border:none;padding:12px 16px;border-radius:12px;font-weight:700}.primary:disabled{opacity:.5;cursor:not-allowed}.error{margin-top:8px;padding:12px 16px;background:#36191dcc;border:1px solid rgba(122,45,54,.7);border-radius:12px;color:#f4b5bf}.viewer{position:relative;width:100%;height:100%;background:#0f111599}.file-tree{position:absolute;inset:0 auto 0 0;width:min(320px,85vw);background:#141821cc;border-right:1px solid rgba(255,255,255,.08);padding:0;z-index:10;overflow-y:auto;backdrop-filter:blur(18px) saturate(120%);-webkit-backdrop-filter:blur(18px) saturate(120%);box-shadow:8px 0 24px #0006}.file-tree__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;border:none;padding:0;background:transparent;z-index:9}.file-tree__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;position:sticky;top:0;z-index:2;background:#141821eb;padding:14px 16px;backdrop-filter:blur(12px) saturate(120%);-webkit-backdrop-filter:blur(12px) saturate(120%)}.file-tree__actions{display:inline-flex;gap:8px}.file-tree__header h2{margin:0;font-size:18px}.file-tree__list{padding:0 16px 14px;margin:0;display:flex;flex-direction:column;gap:6px}.file-tree__item{display:flex}.dir-item{width:100%;display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:0;border:none;background:transparent;color:#dfe3eb;text-align:left;font-weight:600}.dir-item__toggle{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;color:#9aa4b5}.dir-item__name{font-size:14px;letter-spacing:.01em}.chevron{width:14px;height:14px;display:block;transform:rotate(90deg);transition:transform .18s ease}.chevron--collapsed{transform:rotate(0)}.file-item{width:100%;display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.04);background:#1a1f2bb3;color:#dfe3eb;text-align:left;box-shadow:inset 0 0 0 1px #ffffff05}.file-item--active{border-color:#5d7cfa;background:#5d7cfa1f}.badge{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;font-weight:700;font-size:12px}.badge--add{background:#193220;color:#5be38a}.badge--modify{background:#232a3a;color:#8aa2ff}.badge--delete{background:#3a1d1f;color:#ff9ca6}.badge--rename{background:#2f2740;color:#d0b2ff}.badge--binary{background:#2e2e2e;color:#c9cfda}.file-name{font-size:14px;word-break:break-all}.ghost{background:#14182159;color:#c9cfda;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:8px 12px;display:inline-flex;align-items:center;gap:8px}.button-icon{width:16px;height:16px;flex:0 0 auto}.code-viewer{height:100%;overflow:auto;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}.code-viewer .diff{padding:24px 16px 120px;width:max-content;min-width:100%;table-layout:auto;display:inline-table}.code-viewer .diff.diff--wrap{width:100%;max-width:100%;table-layout:fixed;display:table}.binary-placeholder,.empty-state{padding:48px 24px;color:#c9cfda}.binary-placeholder h3{margin-top:0}.floating-button{position:fixed;right:16px;bottom:24px;width:44px;height:44px;padding:0;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#0c0e148c;color:#d7dcea;display:inline-flex;align-items:center;justify-content:center;backdrop-filter:blur(16px) saturate(120%);-webkit-backdrop-filter:blur(16px) saturate(120%);box-shadow:0 12px 28px #0006;z-index:20}.floating-button svg{width:22px;height:22px;fill:currentColor}@media (min-width: 768px){.file-tree{width:360px}.floating-button{bottom:32px}}.code-viewer .diff .diff-gutter{background:#12161fe6;font-size:.7em;padding:0 calc(.15ch + .05em - 1px)}.code-viewer .diff td.diff-gutter{vertical-align:middle}.code-viewer .diff .diff-gutter>a{display:flex;align-items:center;justify-content:flex-end;height:100%}.code-viewer .diff .diff-gutter-col{width:calc(var(--diff-gutter-digits, 2) * 1ch + .35ch + .2em - 1px)}.code-viewer .diff .diff-code{background:#0f1115d9;position:relative;padding-left:2.25em;padding-right:4rem;white-space:pre;word-break:normal;word-wrap:normal}.code-viewer .diff.diff--wrap .diff-code{white-space:pre-wrap;word-break:break-word;word-wrap:anywhere}.code-viewer .diff{font-size:var(--diff-font-size, 1em)}.code-viewer .diff .diff-line{font-family:SF Mono,Fira Code,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace}.code-viewer .diff .diff-code:before{content:" ";position:absolute;left:.75em;width:1ch;color:#96a0ab}.code-viewer .diff .diff-code-insert:before{content:"+";color:#e6e6e6}.code-viewer .diff .diff-code-delete:before{content:"-";color:#e6e6e6}.code-viewer .diff .diff-gutter-insert{background:#12301d;color:#b8f1c7}.code-viewer .diff .diff-gutter-delete{background:#3a1d1f;color:#f7c1c6}.code-viewer .diff .diff-code-insert{background:#2ea04333}.code-viewer .diff .diff-code-delete{background:#f8514933}.settings-list{display:flex;flex-direction:column;gap:10px;padding:0 16px 14px}.settings-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:12px;background:#1a1f2bb3;border:1px solid rgba(255,255,255,.06)}.settings-item__label{font-size:14px;font-weight:600}.settings-item__controls{display:inline-flex;align-items:center;gap:10px}.settings-item__value{font-size:13px;color:#c9cfda;min-width:48px;text-align:center}.settings-button,.settings-toggle{background:#14182180;color:#dfe3eb;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:6px 10px;font-weight:600}.settings-button:disabled{opacity:.5;cursor:not-allowed}.settings-toggle--active{background:#5d7cfa33;border-color:#5d7cfa99;color:#fff}.token{color:#d7dce2}.token.comment,.token.prolog,.token.doctype,.token.cdata{color:#8b98a5}.token.punctuation{color:#b1bac4}.token.property,.token.tag,.token.boolean,.token.number,.token.constant,.token.symbol,.token.deleted{color:#f08d49}.token.selector,.token.attr-name,.token.string,.token.char,.token.builtin,.token.inserted{color:#9ecbff}.token.operator,.token.entity,.token.url,.token.variable{color:#d2a8ff}.token.atrule,.token.attr-value,.token.function,.token.class-name{color:#7ee787}.token.keyword{color:#ff7b72}.token.regex,.token.important{color:#ffa657}.token.bold{font-weight:700}.token.italic{font-style:italic}
