*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #4a90d9;--primary-hover: #3a7bc8;--match-color: #fff3cd;--match-border: #ffc107;--active-color: #ffb74d;--active-border: #ff9800;--text-primary: #333;--text-secondary: #666;--bg-primary: #ffffff;--bg-secondary: #f5f7fa;--border-color: #e0e0e0;--shadow: 0 2px 8px rgba(0, 0, 0, .1);--radius: 8px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:var(--bg-secondary);color:var(--text-primary);line-height:1.6}.app{min-height:100vh;display:flex;flex-direction:column}.error-banner{background-color:#f8d7da;color:#721c24;padding:12px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #f5c6cb}.error-banner button{background:none;border:none;color:#721c24;cursor:pointer;font-weight:500;padding:4px 8px}.error-banner button:hover{text-decoration:underline}.file-selector{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;max-width:900px;margin:0 auto;width:100%}.file-selector-title{font-size:2.5rem;font-weight:700;color:var(--primary-color);margin-bottom:8px}.file-selector-subtitle{font-size:1.1rem;color:var(--text-secondary);margin-bottom:40px}.file-selector-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;width:100%;margin-bottom:32px}@media(max-width:640px){.file-selector-grid{grid-template-columns:1fr}}.file-selector-hint{color:var(--text-secondary);font-size:.9rem;margin-top:16px}.drop-zone{border:2px dashed var(--border-color);border-radius:var(--radius);padding:40px 24px;text-align:center;cursor:pointer;transition:all .2s ease;background-color:var(--bg-primary)}.drop-zone:hover:not(.disabled){border-color:var(--primary-color);background-color:#4a90d90d}.drop-zone.drag-over{border-color:var(--primary-color);background-color:#4a90d91a;transform:scale(1.02)}.drop-zone.has-file{border-color:#28a745;border-style:solid;background-color:#28a7450d}.drop-zone.disabled{opacity:.6;cursor:not-allowed}.drop-zone-content{display:flex;flex-direction:column;align-items:center;gap:12px}.drop-zone-icon{width:48px;height:48px;color:var(--text-secondary)}.drop-zone.has-file .drop-zone-icon{color:#28a745}.drop-zone-label{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.drop-zone-description{font-size:.9rem;color:var(--text-secondary)}.drop-zone-hint{color:var(--primary-color);font-weight:500}.drop-zone-filename{font-size:.9rem;color:#28a745;font-weight:500;word-break:break-all}.compare-button{background-color:var(--primary-color);color:#fff;border:none;padding:14px 48px;font-size:1.1rem;font-weight:600;border-radius:var(--radius);cursor:pointer;transition:all .2s ease}.compare-button:hover:not(:disabled){background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow)}.compare-button:disabled{background-color:#ccc;cursor:not-allowed}.comparison-view{display:flex;flex-direction:column;height:100vh}.comparison-header{display:flex;align-items:center;flex-wrap:wrap;gap:16px 24px;padding:16px 24px;background-color:var(--bg-primary);border-bottom:1px solid var(--border-color);flex-shrink:0}.similarity-control{display:flex;flex-direction:column;gap:4px;min-width:140px;max-width:220px}.similarity-control label{font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.similarity-control input[type=range]{width:100%;cursor:pointer}.back-button{display:flex;align-items:center;gap:8px;background:none;border:1px solid var(--border-color);padding:8px 16px;border-radius:var(--radius);cursor:pointer;font-size:.95rem;color:var(--text-primary);transition:all .2s ease}.back-button:hover{background-color:var(--bg-secondary);border-color:var(--text-secondary)}.back-button svg{width:18px;height:18px}.comparison-stats{display:flex;gap:32px;flex:1;justify-content:center}.stat-item{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:1.5rem;font-weight:700;color:var(--primary-color)}.stat-label{font-size:.85rem;color:var(--text-secondary)}.clear-button{background-color:var(--bg-secondary);border:1px solid var(--border-color);padding:8px 16px;border-radius:var(--radius);cursor:pointer;font-size:.9rem;color:var(--text-secondary);transition:all .2s ease}.clear-button:hover{background-color:#e0e0e0}.comparison-panels{display:grid;grid-template-columns:1fr auto 1fr;flex:1;overflow:hidden}.panel-divider{width:1px;background-color:var(--border-color)}.document-panel{display:flex;flex-direction:column;overflow:hidden;background-color:var(--bg-primary)}.document-panel-header{padding:12px 20px;border-bottom:1px solid var(--border-color);background-color:var(--bg-secondary);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.document-panel-header h2{font-size:1rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.document-panel-stats{font-size:.85rem;color:var(--text-secondary);white-space:nowrap}.document-panel-content{flex:1;overflow-y:auto;padding:20px;scroll-behavior:smooth}.document-panel-content.empty{display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.paragraph{margin-bottom:16px;line-height:1.8}.sentence{transition:background-color .2s ease,box-shadow .2s ease;border-radius:2px;padding:1px 0}.sentence.matched{background-color:transparent;border-bottom:1px dashed rgba(255,193,7,.75)}.sentence.matched.clickable{cursor:pointer}.sentence.matched.clickable:hover{border-bottom-color:var(--match-border)}.sentence .highlight-same{background-color:var(--match-color);border-radius:2px;padding:0 1px}.sentence .highlight-diff{background-color:#ffcdd2;color:var(--text-primary);border-radius:2px;padding:0 1px}.sentence.active{background-color:transparent;border-bottom:2px solid var(--active-border);box-shadow:0 0 0 2px #ff980059}.sentence.active .highlight-same{background-color:#ffe082}.sentence.active .highlight-diff{background-color:#ffab91}.comparison-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:16px 32px;padding:12px 24px;background-color:var(--bg-secondary);border-top:1px solid var(--border-color);flex-shrink:0}.legend-item{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-secondary)}.legend-color{width:24px;height:16px;border-radius:2px}.legend-color.matched{background-color:var(--match-color);border:1px solid var(--match-border)}.legend-color.active{background-color:var(--active-color);border:1px solid var(--active-border)}.legend-swatch{width:24px;height:16px;border-radius:2px;flex-shrink:0}.legend-swatch-same{background-color:var(--match-color);border:1px solid var(--match-border)}.legend-swatch-diff{background-color:#ffcdd2;border:1px solid #e57373}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#fffffff2;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000}.loading-content{display:flex;flex-direction:column;align-items:center;max-width:500px;width:90%;padding:20px}.loading-spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.loading-title{color:var(--text-primary);font-size:1.2rem;font-weight:600;margin-bottom:24px}.progress-container{width:100%;display:flex;flex-direction:column;gap:20px}.progress-item{display:flex;flex-direction:column;gap:8px}.progress-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.progress-label{font-size:.9rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:50%}.progress-stage{font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.progress-bar{width:100%;height:8px;background-color:var(--bg-secondary);border-radius:4px;overflow:hidden;position:relative}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-color) 0%,var(--primary-hover) 100%);border-radius:4px;transition:width .3s ease;position:relative}.progress-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-percent{font-size:.85rem;font-weight:600;color:var(--primary-color);text-align:right}@media(max-width:768px){.comparison-header{flex-wrap:wrap;gap:12px}.comparison-stats{order:3;width:100%;justify-content:space-around}.comparison-panels{grid-template-columns:1fr;grid-template-rows:1fr auto 1fr}.panel-divider{width:100%;height:1px}.comparison-legend{flex-wrap:wrap;gap:16px}.excel-panels{grid-template-columns:1fr;grid-template-rows:1fr auto 1fr}}.match-mode-toggle{display:flex;border:1px solid var(--border-color);border-radius:var(--radius);overflow:hidden}.mode-btn{padding:6px 14px;font-size:.82rem;border:none;background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;transition:all .15s ease;white-space:nowrap}.mode-btn:not(:last-child){border-right:1px solid var(--border-color)}.mode-btn:hover:not(.active){background-color:var(--bg-secondary)}.mode-btn.active{background-color:var(--primary-color);color:#fff}.excel-comparison-view{display:flex;flex-direction:column;height:100vh}.excel-panels{display:grid;grid-template-columns:1fr auto 1fr;flex:1;overflow:hidden}.excel-panel-wrapper{position:relative;display:flex;flex-direction:column;overflow:hidden}.excel-peek-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:15;margin:0;padding:0;border:none;background:#0000000d;cursor:pointer}.excel-match-peek{position:absolute;bottom:12px;right:12px;z-index:20;max-width:min(300px,calc(100% - 24px));max-height:min(42vh,360px);display:flex;flex-direction:column;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius);box-shadow:0 4px 24px #0000001f;overflow:hidden}.excel-match-peek-header{display:flex;flex-wrap:wrap;align-items:center;gap:6px 10px;padding:8px 10px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);font-size:.75rem}.excel-match-peek-title{flex:1 1 auto;min-width:0;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.excel-match-peek-pos{font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.excel-match-peek-count{font-weight:500;color:var(--text-secondary)}.excel-match-peek-actions{display:flex;align-items:center;gap:2px;margin-left:auto}.excel-match-peek-nav,.excel-match-peek-close{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 6px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:1rem;line-height:1;cursor:pointer}.excel-match-peek-nav:disabled{opacity:.35;cursor:not-allowed}.excel-match-peek-nav:hover:not(:disabled),.excel-match-peek-close:hover{background:var(--bg-secondary)}.excel-match-peek-close{font-size:1.25rem;font-weight:300}.excel-match-peek-body{overflow:auto;padding:6px;max-height:280px}.excel-peek-grid{border-collapse:collapse;font-size:.72rem;width:100%}.excel-peek-grid th,.excel-peek-grid td{border:1px solid var(--border-color);padding:3px 6px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.excel-peek-corner,.excel-peek-col-h,.excel-peek-row-h{background:#e8ecf0;color:var(--text-secondary);font-weight:600;text-align:center}.excel-peek-cell-hit{background:#4a90d938;box-shadow:inset 0 0 0 1px #4a90d98c}.sheet-tabs{display:flex;align-items:center;gap:4px;padding:6px 12px;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);overflow-x:auto;flex-shrink:0}.sheet-tabs-label{font-size:.8rem;color:var(--text-secondary);margin-right:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.sheet-tab{padding:4px 12px;font-size:.8rem;border:1px solid var(--border-color);border-radius:4px 4px 0 0;background:var(--bg-primary);cursor:pointer;white-space:nowrap;color:var(--text-secondary);transition:all .15s ease}.sheet-tab:hover{background-color:#4a90d914}.sheet-tab.active{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}.excel-panel{display:flex;flex-direction:column;overflow:hidden;background-color:var(--bg-primary);flex:1}.excel-panel-header{padding:10px 16px;border-bottom:1px solid var(--border-color);background-color:var(--bg-secondary);flex-shrink:0}.excel-panel-header h2{font-size:.95rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.excel-panel-content{flex:1;overflow:auto}.excel-grid{border-collapse:collapse;font-size:.82rem;min-width:100%}.excel-grid th,.excel-grid td{border:1px solid var(--border-color);padding:4px 8px;white-space:nowrap;max-width:240px;overflow:hidden;text-overflow:ellipsis}.excel-corner{position:sticky;top:0;left:0;z-index:3;background-color:#e8ecf0;min-width:40px}.excel-col-header{position:sticky;top:0;z-index:2;background-color:#e8ecf0;text-align:center;font-weight:600;color:var(--text-secondary);min-width:72px}.excel-row-header{position:sticky;left:0;z-index:1;background-color:#e8ecf0;text-align:center;font-weight:600;color:var(--text-secondary);min-width:40px}.cell-same{background-color:#e8f5e9}.cell-diff{background-color:#ffcdd2}.cell-only-left,.cell-only-right{background-color:#f5f5f5;color:#999}.excel-cell{cursor:pointer}.cell-match-peeking{box-shadow:inset 0 0 0 1px #4a90d980;background-color:#4a90d91a!important}.legend-item-hint{flex-basis:100%;justify-content:center}.legend-item-hint .legend-label{font-size:.78rem;color:var(--text-secondary);max-width:42rem;text-align:center}.legend-swatch-cell-same{background-color:#e8f5e9;border:1px solid #a5d6a7}.legend-swatch-cell-diff{background-color:#ffcdd2;border:1px solid #e57373}.legend-swatch-cell-only{background-color:#f5f5f5;border:1px solid #ccc}.batch-view{max-width:1600px;margin:0 auto;padding:24px 20px 60px}.batch-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.batch-title{font-size:1.5rem;font-weight:700;color:var(--primary-color)}.batch-config{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius);padding:16px 20px;margin-bottom:20px}.batch-config-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.batch-label{font-weight:600;white-space:nowrap;color:var(--text-primary)}.batch-input{border:1px solid var(--border-color);border-radius:6px;padding:6px 12px;font-size:.95rem;width:260px;outline:none;transition:border-color .2s}.batch-input:focus{border-color:var(--primary-color)}.batch-hint{font-size:.82rem;color:var(--text-secondary)}.batch-dropzone{border:2px dashed var(--border-color);border-radius:var(--radius);padding:40px 20px;text-align:center;cursor:pointer;transition:border-color .2s,background-color .2s;margin-bottom:16px;color:var(--text-secondary)}.batch-dropzone:hover,.batch-dropzone.drag-over{border-color:var(--primary-color);background-color:#f0f6ff}.batch-dropzone-icon{width:40px;height:40px;margin:0 auto 12px;display:block;color:var(--primary-color)}.batch-dropzone p{font-size:1rem;margin-bottom:4px;color:var(--text-primary)}.batch-dropzone-hint{font-size:.8rem}.batch-file-list{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius);margin-bottom:16px;max-height:240px;overflow-y:auto}.batch-file-list-header{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-bottom:1px solid var(--border-color);font-weight:600;font-size:.9rem;position:sticky;top:0;background:var(--bg-primary);z-index:1}.batch-link-btn{background:none;border:none;color:var(--primary-color);cursor:pointer;font-size:.85rem;padding:2px 6px}.batch-link-btn:hover{text-decoration:underline}.batch-file-list ul{list-style:none;padding:0;margin:0}.batch-file-list li{display:flex;align-items:center;justify-content:space-between;padding:6px 16px;border-bottom:1px solid #f0f0f0;font-size:.88rem}.batch-file-list li:last-child{border-bottom:none}.batch-file-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.batch-file-remove{background:none;border:none;color:#999;cursor:pointer;font-size:1.2rem;padding:0 4px;line-height:1;flex-shrink:0}.batch-file-remove:hover{color:#e53935}.batch-error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca;border-radius:var(--radius);padding:10px 16px;margin-bottom:16px;display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.batch-error button{background:none;border:none;color:#b91c1c;cursor:pointer;font-size:1.2rem;padding:0 4px}.batch-compare-btn{width:100%;margin-bottom:20px}.batch-unpaired{background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius);padding:16px;margin-bottom:20px}.batch-unpaired h3{font-size:.95rem;margin-bottom:10px;color:#92400e}.batch-unpaired-item{display:flex;gap:12px;align-items:baseline;font-size:.88rem;padding:4px 0;flex-wrap:wrap}.batch-unpaired-code{font-weight:700;font-family:monospace;color:#92400e}.batch-unpaired-reason{color:#b45309}.batch-unpaired-files{color:var(--text-secondary);font-size:.82rem;word-break:break-all}.batch-results-summary{display:flex;gap:16px;margin-bottom:16px;flex-wrap:wrap}.batch-stat{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius);padding:12px 20px;text-align:center;min-width:100px}.batch-stat-value{display:block;font-size:1.6rem;font-weight:700;color:var(--text-primary)}.batch-stat-label{font-size:.82rem;color:var(--text-secondary)}.batch-stat-pass{border-color:#a5d6a7}.batch-stat-pass .batch-stat-value{color:#2e7d32}.batch-stat-fail{border-color:#ef9a9a}.batch-stat-fail .batch-stat-value{color:#c62828}.batch-stat-error{border-color:#ffcc80}.batch-stat-error .batch-stat-value{color:#e65100}.batch-table{width:100%;border-collapse:collapse;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius);overflow:hidden;font-size:.88rem}.batch-table th{background:var(--bg-secondary);padding:10px 12px;text-align:left;font-weight:600;border-bottom:2px solid var(--border-color);white-space:nowrap}.batch-table td{padding:10px 12px;border-bottom:1px solid #f0f0f0;vertical-align:middle}.batch-row-clickable{cursor:pointer}.batch-row-clickable:hover td{background:#fafafa}.batch-cell-code{font-family:monospace;font-weight:600}.batch-cell-file{max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.batch-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:.8rem;font-weight:600}.batch-badge-pass{background:#e8f5e9;color:#2e7d32}.batch-badge-fail{background:#ffebee;color:#c62828}.batch-badge-error{background:#fff3e0;color:#e65100}.batch-expand-icon{margin-left:8px;font-size:.75rem;color:var(--text-secondary)}.batch-cell-actions{white-space:nowrap}.batch-detail-btn{margin-left:8px;padding:2px 10px;font-size:.78rem;font-weight:500;border:1px solid #c62828;border-radius:4px;background:transparent;color:#c62828;cursor:pointer;transition:background .15s,color .15s}.batch-detail-btn:hover:not(:disabled){background:#c62828;color:#fff}.batch-detail-btn:disabled{opacity:.5;cursor:not-allowed}.batch-detail-row td{padding:0;background:#fafafa}.batch-detail{padding:12px 16px}.batch-detail-error{padding:12px 16px;color:#e65100}.batch-detail-title{font-weight:600;margin-bottom:8px;font-size:.85rem}.batch-detail-table{width:100%;border-collapse:collapse;font-size:.84rem}.batch-detail-table th{background:#f5f5f5;padding:6px 10px;text-align:left;font-weight:600;border-bottom:1px solid var(--border-color)}.batch-detail-table td{padding:5px 10px;border-bottom:1px solid #eee;font-family:monospace}
