@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root,[data-theme=dark]{--font-sans:"Inter", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--bg:#0d1117;--surface:#161b22;--surface-alt:#1a2030;--editor-bg:#0d1117;--header-bg:#161b22eb;--border:#30363d;--border-subtle:#21262d;--text-primary:#e6edf3;--text-secondary:#8b949e;--text-muted:#484f58;--accent:#7c6af9;--accent-alt:#5b8af8;--accent-gradient:linear-gradient(135deg, #7c6af9 0%, #5b8af8 100%);--accent-subtle:#7c6af91f;--accent-glow:#7c6af94d;--green:#3fb950;--green-bg:#2ea04326;--red:#f85149;--red-bg:#f8514926;--yellow:#d29922;--yellow-bg:#d2992226;--added-line-bg:#2ea0431f;--added-line-text:#3fb950;--removed-line-bg:#f851491f;--removed-line-text:#f85149;--modified-line-bg:#d299221f;--modified-line-text:#d29922;--equal-line-bg:transparent;--empty-line-bg:#ffffff05;--token-added-bg:#2ea04359;--token-added-text:#7ee787;--token-removed-bg:#f8514959;--token-removed-text:#ffa198;--line-num-bg:#161b22;--line-num-color:#484f58;--merge-gutter-bg:#161b22;--scrollbar-thumb:#30363d}[data-theme=light]{--bg:#f6f8fa;--surface:#fff;--surface-alt:#f0f2f5;--editor-bg:#fff;--header-bg:#f6f8faeb;--border:#d0d7de;--border-subtle:#e5e9ef;--text-primary:#1f2328;--text-secondary:#57606a;--text-muted:#9a9fa6;--accent:#6f5fd4;--accent-alt:#4c7ef0;--accent-gradient:linear-gradient(135deg, #6f5fd4 0%, #4c7ef0 100%);--accent-subtle:#6f5fd41a;--accent-glow:#6f5fd433;--green:#1a7f37;--green-bg:#1a7f371f;--red:#d1242f;--red-bg:#d1242f1a;--yellow:#9a6700;--yellow-bg:#9a67001a;--added-line-bg:#1a7f3717;--added-line-text:#1a7f37;--removed-line-bg:#d1242f14;--removed-line-text:#d1242f;--modified-line-bg:#9a670017;--modified-line-text:#7d5a00;--equal-line-bg:transparent;--empty-line-bg:#00000005;--token-added-bg:#1a7f3747;--token-added-text:#116329;--token-removed-bg:#d1242f47;--token-removed-text:#82071e;--line-num-bg:#f6f8fa;--line-num-color:#b0b7be;--merge-gutter-bg:#f6f8fa;--scrollbar-thumb:#d0d7de}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);background:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;line-height:1.5;overflow-x:hidden}#root{flex-direction:column;min-height:100dvh;display:flex}.app{background:var(--bg);flex-direction:column;min-height:100dvh;transition:background .3s,color .3s;display:flex}::-webkit-scrollbar{width:7px;height:7px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:4px}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}button{font-family:var(--font-sans)}.app-header{background:var(--header-bg);border-bottom:1px solid var(--border);z-index:100;-webkit-backdrop-filter:blur(12px);justify-content:space-between;align-items:center;height:64px;padding:0 24px;display:flex;position:sticky;top:0}.logo{align-items:center;gap:10px;display:flex}.logo-icon{background:var(--accent-gradient);color:#fff;width:38px;height:38px;box-shadow:0 4px 14px var(--accent-glow);border-radius:10px;justify-content:center;align-items:center;display:flex}.logo-text{letter-spacing:-.5px;color:var(--text-primary);font-size:1.4rem;font-weight:800}.logo-accent{color:var(--accent)}.header-tagline{color:var(--text-muted);border-left:1px solid var(--border);white-space:nowrap;margin-left:14px;padding-left:14px;font-size:.75rem}.header-right{align-items:center;gap:16px;display:flex}.stats-banner{background:var(--surface-alt);border:1px solid var(--border);font-size:.78rem;font-weight:600;font-family:var(--font-mono);border-radius:20px;align-items:center;gap:6px;padding:4px 12px;animation:.3s fadeIn;display:flex}.stat{border-radius:6px;padding:2px 6px}.stat-added{color:var(--green);background:var(--green-bg)}.stat-removed{color:var(--red);background:var(--red-bg)}.stat-modified{color:var(--yellow);background:var(--yellow-bg)}.stat-unchanged{color:var(--text-muted)}.theme-toggle{border:1px solid var(--border);background:var(--surface-alt);width:38px;height:38px;color:var(--text-secondary);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;transition:all .2s;display:flex}.theme-toggle:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle);transform:scale(1.05)}@media (width<=640px){.header-tagline{display:none}.stats-banner{padding:3px 8px;font-size:.7rem}}.diff-viewer{background:var(--editor-bg);font-family:var(--font-mono);scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) transparent;flex:1;font-size:13px;line-height:1.6;overflow:auto}.diff-viewer::-webkit-scrollbar{width:6px;height:6px}.diff-viewer::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:3px}.diff-table{border-collapse:collapse;table-layout:fixed;width:100%}.diff-table colgroup col:first-child,.diff-table colgroup col:nth-child(5),.diff-table colgroup col:nth-child(3){width:52px}.diff-table colgroup col:nth-child(2),.diff-table colgroup col:nth-child(4){width:auto}.diff-empty{height:320px;color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:24px;display:flex}.diff-empty-icon{font-size:3rem;animation:2s ease-in-out infinite pulse}.diff-empty p{max-width:340px;font-size:.9rem;line-height:1.6;font-family:var(--font-sans)}.line-num{text-align:right;width:52px;min-width:52px;color:var(--line-num-color);-webkit-user-select:none;user-select:none;background:var(--line-num-bg);border-right:1px solid var(--border-subtle);vertical-align:top;white-space:nowrap;padding:1px 10px;font-size:11.5px}.right-num{border-right:none;border-left:1px solid var(--border-subtle);text-align:left}.line-content{white-space:pre;text-overflow:ellipsis;vertical-align:top;padding:1px 12px;overflow:hidden}.line-content span{min-height:1em}.line-equal .line-content span,.line-content>span{min-height:1em;display:block}.line-added{background:var(--added-line-bg);color:var(--added-line-text)}.line-removed{background:var(--removed-line-bg);color:var(--removed-line-text)}.line-modified{background:var(--modified-line-bg);color:var(--modified-line-text)}.line-equal{background:var(--equal-line-bg);color:var(--text-primary)}.line-empty{background:var(--empty-line-bg)}.diff-row:hover .line-content,.diff-row:hover .line-num{filter:brightness(1.1)}.merge-gutter{text-align:center;vertical-align:top;background:var(--merge-gutter-bg);border-left:1px solid var(--border-subtle);border-right:1px solid var(--border-subtle);width:52px;min-width:52px;padding:1px 4px}.merge-buttons{flex-direction:column;align-items:center;gap:2px;display:flex}.merge-btn{cursor:pointer;opacity:0;width:22px;height:18px;color:var(--text-muted);background:0 0;border:1px solid #0000;border-radius:4px;justify-content:center;align-items:center;transition:all .15s;display:flex}.diff-row:hover .merge-btn{opacity:1}.merge-right:hover{background:var(--green-bg);border-color:var(--green);color:var(--green);transform:scale(1.1)}.merge-left:hover{background:var(--red-bg);border-color:var(--red);color:var(--red);transform:scale(1.1)}.inline-diff{white-space:pre-wrap;min-height:1em;display:block}.inline-diff span{display:inline}.token-added{background:var(--token-added-bg);color:var(--token-added-text);border-radius:2px}.token-removed{background:var(--token-removed-bg);color:var(--token-removed-text);opacity:.8;border-radius:2px;text-decoration:line-through}@keyframes pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.diff-legend{background:var(--surface-alt);border-top:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:16px;padding:8px 20px;display:flex}.legend-item{color:var(--text-secondary);font-size:.75rem;font-family:var(--font-sans);align-items:center;gap:6px;display:flex}.legend-swatch{border:1px solid #0000;border-radius:4px;flex-shrink:0;width:14px;height:14px}.legend-added{background:var(--added-line-bg);border-color:var(--green)}.legend-removed{background:var(--removed-line-bg);border-color:var(--red)}.legend-modified{background:var(--modified-line-bg);border-color:var(--yellow)}.legend-equal{background:var(--equal-line-bg);border-color:var(--border)}.hero-section{text-align:center;background:radial-gradient(70% 300px at 50% 0,#22c55e14 0%,#0000 70%);flex-shrink:0;padding:36px 24px 16px}.hero-title{letter-spacing:-.03em;color:var(--text-primary);background:linear-gradient(135deg, var(--text-primary) 0%, var(--text-secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:10px;font-size:clamp(2rem,5vw,3.2rem);font-weight:800}.hero-subtitle{color:var(--text-secondary);max-width:520px;margin:0 auto;font-size:.95rem;line-height:1.6}.options-bar{flex-shrink:0;justify-content:center;align-items:center;gap:32px;padding:12px 24px;display:flex}.option-item{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;display:flex}.option-label{color:var(--text-secondary);font-size:.85rem;font-weight:500}.toggle-switch{background:var(--surface-alt);border:1px solid var(--border);cursor:pointer;border-radius:12px;flex-shrink:0;width:42px;height:24px;transition:background .2s,border-color .2s;position:relative}.toggle-switch.toggle-on{background:var(--green);border-color:var(--green)}.toggle-knob{background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #0000004d}.toggle-on .toggle-knob{transform:translate(18px)}.compare-group{background:var(--surface-alt);border:1px solid var(--border);border-radius:20px;gap:2px;padding:3px;display:flex}.compare-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:16px;padding:4px 16px;font-size:.82rem;font-weight:600;transition:all .2s}.compare-btn.compare-active{background:var(--green);color:#fff;box-shadow:0 2px 8px #22c55e59}.checker-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;flex:1;min-height:0;margin:0 24px 16px;display:flex;overflow:hidden}.card-header{background:var(--surface-alt);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 18px;display:flex}.card-title{color:var(--text-primary);align-items:center;gap:8px;font-size:.88rem;font-weight:700;display:flex}.card-reset-btn{border:1px solid var(--border);background:var(--surface);width:32px;height:32px;color:var(--text-muted);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.card-reset-btn:hover{color:var(--text-primary);background:var(--surface-alt);border-color:var(--accent);transform:rotate(-30deg)}.input-editors-row{flex:1;gap:0;min-height:0;display:flex}.input-editor-col{border-right:1px solid var(--border);flex-direction:column;flex:1;min-width:0;display:flex}.input-editor-col:last-child{border-right:none}.input-editor-label{color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);background:var(--surface-alt);letter-spacing:.01em;flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:7px 10px 7px 14px;font-size:.8rem;font-weight:600;display:flex}.editor-label-text{flex-shrink:0}.editor-label-actions{align-items:center;gap:4px;display:flex}.editor-action-btn{border:1px solid var(--border);background:var(--surface);color:var(--text-muted);font-size:.72rem;font-weight:600;font-family:var(--font-sans);cursor:pointer;white-space:nowrap;border-radius:6px;align-items:center;gap:4px;padding:3px 9px;transition:all .15s;display:inline-flex}.editor-action-btn:hover:not(:disabled){color:var(--text-primary);background:var(--surface-alt);border-color:var(--accent)}.editor-action-btn:disabled{opacity:.35;cursor:not-allowed}.editor-action-btn.editor-action-copied{color:var(--green);border-color:var(--green);background:#22c55e14}.input-editor-box{background:var(--editor-bg);flex:1;min-height:0;display:flex;overflow:hidden}.input-line-numbers{background:var(--line-num-bg);border-right:1px solid var(--border-subtle);-webkit-user-select:none;user-select:none;flex-shrink:0;width:48px;min-width:48px;padding:12px 0;overflow:hidden}.input-line-num{text-align:right;height:22px;line-height:22px;font-family:var(--font-mono);color:var(--line-num-color);padding-right:10px;font-size:12px}.input-textarea{resize:none;font-family:var(--font-mono);color:var(--text-primary);scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) transparent;background:0 0;border:none;outline:none;flex:1;padding:12px 14px;font-size:13px;line-height:22px;overflow:auto}.input-textarea::placeholder{color:var(--text-muted);opacity:.6}.card-footer{background:var(--surface-alt);border-top:1px solid var(--border);flex-shrink:0;justify-content:center;align-items:center;padding:14px 18px;display:flex}.submit-btn{font-size:.9rem;font-weight:700;font-family:var(--font-sans);background:var(--accent-gradient);color:#fff;cursor:pointer;box-shadow:0 4px 16px var(--accent-glow);letter-spacing:.02em;border:none;border-radius:24px;align-items:center;gap:8px;padding:11px 32px;transition:all .2s;display:flex}.submit-btn:hover:not(:disabled){box-shadow:0 6px 24px var(--accent-glow);filter:brightness(1.1);transform:translateY(-2px)}.submit-btn:active:not(:disabled){transform:translateY(0)}.submit-btn:disabled{opacity:.35;cursor:not-allowed;box-shadow:none}.result-overlay{z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000000a6;justify-content:center;align-items:center;padding:24px;transition:opacity .25s;display:flex;position:fixed;inset:0}.result-entering{opacity:0}.result-visible{opacity:1}.result-window{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;width:min(1100px,100%);max-height:88vh;animation:.28s cubic-bezier(.34,1.56,.64,1) both scaleInModal;display:flex;overflow:hidden;box-shadow:0 0 0 1px #ffffff0f,0 24px 80px #0000008c}@keyframes scaleInModal{0%{opacity:0;transform:scale(.92)translateY(12px)}to{opacity:1;transform:scale(1)translateY(0)}}.result-window-header{background:var(--surface-alt);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:12px;padding:12px 18px;display:flex}.result-window-dots{flex-shrink:0;gap:6px;display:flex}.dot{border-radius:50%;width:12px;height:12px}.dot-red{background:#ff5f57}.dot-yellow{background:#ffbd2e}.dot-green{background:#28c840}.result-window-title{text-align:center;color:var(--text-primary);flex:1;margin-right:32px;font-size:.85rem;font-weight:700}.result-close-btn{border:1px solid var(--border);background:var(--surface);width:32px;height:32px;color:var(--text-muted);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.result-close-btn:hover{background:var(--red-bg);border-color:var(--red);color:var(--red)}.result-stats-bar{background:var(--surface-alt);border-bottom:1px solid var(--border);font-size:.82rem;font-family:var(--font-mono);flex-shrink:0;align-items:center;gap:24px;padding:10px 20px;display:flex}.result-stat{color:var(--text-secondary)}.result-stat strong{margin-left:4px;font-weight:700}.stat-common strong{color:var(--text-secondary)}.stat-new strong{color:var(--green)}.stat-removed strong{color:var(--red)}.stat-modified strong{color:var(--yellow)}.result-diff-area{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) transparent;flex:1;min-height:0;overflow:auto}.app-footer{color:var(--text-muted);background:var(--surface-alt);border-top:1px solid var(--border);flex-shrink:0;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:.72rem;display:flex}.footer-sep{opacity:.4}@media (width<=768px){.hero-section{padding:24px 16px 12px}.options-bar{flex-wrap:wrap;gap:16px}.checker-card{margin:0 12px 12px}.input-editors-row{flex-direction:column}.input-editor-col{border-right:none;border-bottom:1px solid var(--border);min-height:200px}.result-window{height:90vh}}
