.auth-modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.auth-modal.hidden{display:none}.auth-modal-content{background:var(--color-paper);border-radius:16px;padding:32px;max-width:420px;width:100%;text-align:center;box-shadow:0 20px 60px #0003}.auth-modal-content h2{margin:0 0 8px;font-size:24px;color:var(--color-ink)}.auth-subtitle{margin:0 0 24px;color:var(--color-ink-light);font-size:14px}.auth-options{display:flex;flex-direction:column;gap:12px}.auth-option{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--color-cream);border:2px solid transparent;border-radius:12px;cursor:pointer;transition:all .2s;text-align:left;font-family:inherit}.auth-option:hover{border-color:var(--color-terracotta);background:#fff}.auth-option-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.auth-option-icon.guest{background:#e0e7ff;color:#4f46e5}.auth-option-icon.pro{background:#fef3c7;color:#d97706}.auth-option-text{display:flex;flex-direction:column;gap:4px}.auth-option-title{font-weight:600;font-size:15px;color:var(--color-ink)}.auth-option-desc{font-size:13px;color:var(--color-ink-light)}.auth-password-form{margin-top:20px}.auth-password-form input{width:100%;padding:12px 16px;border:2px solid var(--color-border);border-radius:8px;font-size:15px;font-family:inherit;margin-bottom:12px}.auth-password-form input:focus{outline:none;border-color:var(--color-terracotta)}.auth-password-actions{display:flex;gap:8px}.auth-password-actions .btn{flex:1}.auth-error{color:#dc2626;font-size:13px;margin:12px 0 0}.access-mode-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:500;margin-left:12px;vertical-align:middle}.access-mode-badge.guest{background:#e0e7ff;color:#4f46e5}.access-mode-badge.pro{background:#fef3c7;color:#d97706}.merge-container{max-width:1400px;margin:0 auto;padding:24px 32px}.upload-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:16px}.upload-box{position:relative}.upload-label{font-size:14px;font-weight:600;color:var(--color-ink);margin-bottom:12px}.upload-area{background:var(--color-paper);border:2px dashed var(--color-border);border-radius:12px;padding:32px 24px;text-align:center;cursor:pointer;transition:all .2s}.upload-area:hover,.upload-area.dragover{border-color:var(--color-terracotta);background:var(--color-cream)}.upload-area.has-file,.upload-area input[type=file]{display:none}.upload-icon{width:48px;height:48px;margin:0 auto 12px;background:var(--color-cream);border-radius:50%;display:flex;align-items:center;justify-content:center}.upload-icon svg{width:24px;height:24px;stroke:var(--color-ink-light)}.upload-text{color:var(--color-ink-light);font-size:14px;margin:0}.upload-hint{font-size:12px;color:var(--color-ink-light);margin:4px 0 0}.files-list{display:flex;flex-direction:column;gap:8px;margin-top:12px}.file-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--color-cream);border-radius:8px}.file-item.uploading{opacity:.7}.file-item.error{background:#fef2f2;border:1px solid #fca5a5}.file-item .file-icon{width:32px;height:32px;background:var(--color-terracotta);border-radius:6px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:600;flex-shrink:0}.file-item .file-details{flex:1;min-width:0}.file-item .file-name{font-weight:500;color:var(--color-ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-item .file-meta{font-size:12px;color:var(--color-ink-light)}.file-item .file-progress{height:4px;background:#e5e7eb;border-radius:2px;margin-top:6px;overflow:hidden}.file-item .file-progress-bar{height:100%;background:var(--color-terracotta);border-radius:2px;transition:width .2s ease-out}.file-item .btn-remove{width:24px;height:24px;border:none;background:transparent;border-radius:50%;cursor:pointer;font-size:16px;color:var(--color-ink-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}.file-item .btn-remove:hover{background:#fef2f2;color:#dc2626}.files-summary{display:flex;align-items:center;justify-content:space-between;margin-top:12px;padding:12px 16px;background:#ecfdf5;border-radius:8px;border:1px solid #a7f3d0}.files-summary .summary-text{font-size:13px;color:#065f46;font-weight:500}.btn-clear{padding:6px 12px;font-size:12px;border:1px solid #a7f3d0;background:#fff;border-radius:4px;cursor:pointer;color:#065f46}.btn-clear:hover{background:#d1fae5}.btn-add-more{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 16px;margin-top:8px;background:var(--color-paper);border:2px dashed var(--color-border);border-radius:8px;color:var(--color-ink-light);font-size:13px;font-family:inherit;cursor:pointer;transition:all .2s}.btn-add-more:hover{border-color:var(--color-terracotta);color:var(--color-terracotta);background:var(--color-cream)}.btn-add-more:disabled{opacity:.5;cursor:not-allowed}.btn-add-more:disabled:hover{border-color:var(--color-border);color:var(--color-ink-light);background:var(--color-paper)}.upload-area.disabled,.upload-box.disabled .upload-area,.upload-box.disabled .btn-add-more{opacity:.5;cursor:not-allowed;pointer-events:none}.upload-box.disabled .files-list{opacity:.7}.upload-status{margin-top:16px;padding:12px 16px;background:#eff6ff;border-radius:8px;border:1px solid #bfdbfe}.upload-progress{height:4px;background:#dbeafe;border-radius:2px;overflow:hidden;margin-bottom:8px}.upload-progress-bar{height:100%;background:var(--color-terracotta);width:0%;transition:width .3s}.upload-status-text{font-size:13px;color:#1e40af}.spreadsheet-container{border:1px solid var(--color-border);border-radius:8px;overflow:hidden;background:var(--color-paper);margin-bottom:24px}.sheet-tabs{display:flex;background:#f3f4f6;border-bottom:1px solid var(--color-border);padding:0 8px;gap:2px}.sheet-tab{display:flex;align-items:center;gap:8px;padding:10px 16px;background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:13px;font-family:inherit;color:var(--color-ink-light);transition:all .15s;margin-bottom:-1px}.sheet-tab:hover{background:#ffffff80;color:var(--color-ink)}.sheet-tab.active{background:var(--color-paper);color:var(--color-ink);border-bottom-color:var(--color-terracotta);font-weight:500}.tab-icon{width:20px;height:20px;background:var(--color-terracotta);color:#fff;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600}.sheet-tab[data-tab=b] .tab-icon{background:#8b5cf6}.tab-name{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tab-meta{font-size:11px;color:var(--color-ink-light);background:var(--color-cream);padding:2px 6px;border-radius:4px}.sheet-content{position:relative}.sheet-panel{display:none}.sheet-panel.active{display:block}.spreadsheet-wrapper{overflow:auto;max-height:400px}.results-spreadsheet{max-height:500px}.spreadsheet{width:100%;border-collapse:collapse;font-size:13px;table-layout:auto}.spreadsheet th,.spreadsheet td{padding:8px 12px;text-align:left;border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border);white-space:nowrap;min-width:100px;max-width:300px;overflow:hidden;text-overflow:ellipsis}.spreadsheet th:last-child,.spreadsheet td:last-child{border-right:none}.spreadsheet th{background:#f9fafb;font-weight:600;position:sticky;top:0;z-index:10;color:var(--color-ink)}.spreadsheet tbody tr:hover td{background:#f9fafb}.spreadsheet .row-num{background:#f3f4f6;color:var(--color-ink-light);font-size:11px;text-align:center;min-width:50px;max-width:50px;position:sticky;left:0;z-index:5}.spreadsheet th.row-num{z-index:15}.join-type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.join-option input{display:none}.join-card{padding:16px;border:2px solid var(--color-border);border-radius:8px;text-align:center;cursor:pointer;transition:all .2s}.join-option input:checked+.join-card{border-color:var(--color-terracotta);background:#0284c70d}.join-icon{height:32px;margin-bottom:8px}.join-icon svg{height:24px;width:auto}.join-name{display:block;font-weight:600;font-size:14px;color:var(--color-ink);margin-bottom:4px}.join-desc{font-size:11px;color:var(--color-ink-light)}.key-selection-grid{display:flex;align-items:center;gap:16px;max-width:600px}.key-select-box{flex:1}.key-label{display:block;font-size:12px;color:var(--color-ink-light);margin-bottom:6px}.key-equals{font-size:24px;color:var(--color-ink-light);padding-top:20px}.key-stats{margin-top:8px;font-size:12px;color:var(--color-ink-light)}.key-stats strong{color:var(--color-ink)}.match-preview{margin-top:20px;padding:16px;background:#ecfdf5;border-radius:8px;border:1px solid #a7f3d0}.match-preview.warning{background:#fffbeb;border-color:#fcd34d}.match-preview.error{background:#fef2f2;border-color:#fca5a5}.match-preview-content{display:flex;align-items:center;gap:12px}.match-icon{color:#059669;flex-shrink:0}.match-preview.warning .match-icon{color:#d97706}.match-preview.error .match-icon{color:#dc2626}.match-text{font-size:14px;color:var(--color-ink)}.match-text strong{font-weight:600}.match-details{display:block;font-size:12px;color:var(--color-ink-light);margin-top:2px}.file-size-warning{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fffbeb;border:1px solid #fcd34d;border-radius:8px;margin-top:12px;font-size:13px;color:#92400e}.file-size-warning.error{background:#fef2f2;border-color:#fca5a5;color:#991b1b}.backend-notice{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;margin-top:16px;font-size:13px;color:#1e40af}.backend-notice svg{flex-shrink:0}.form-hint{font-size:13px;color:var(--color-ink-light);margin:4px 0 16px}.columns-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:8px;margin-bottom:16px;max-height:400px;overflow-y:auto;padding:4px}.column-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--color-cream);border-radius:6px;font-size:13px}.column-item input[type=checkbox]{width:16px;height:16px;cursor:pointer;flex-shrink:0}.column-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.column-source{font-size:11px;color:#fff;padding:2px 8px;border-radius:4px;flex-shrink:0}.column-source.source-a{background:var(--color-terracotta)}.column-source.source-b{background:#8b5cf6}.columns-actions{display:flex;gap:8px}.btn-small{padding:8px 12px;font-size:12px}.summary-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:24px}.summary-card{background:var(--color-cream);padding:16px;border-radius:8px;text-align:center}.summary-card.highlight{background:#0284c71a}.summary-card.success{background:#ecfdf5}.summary-card.warning{background:#fffbeb}.summary-value{display:block;font-size:24px;font-weight:700;color:var(--color-ink);margin-bottom:4px}.summary-card.highlight .summary-value{color:var(--color-terracotta)}.summary-card.success .summary-value{color:#059669}.summary-card.warning .summary-value{color:#d97706}.summary-label{font-size:12px;color:var(--color-ink-light)}.results-section{margin-bottom:24px}.results-section h3{font-size:14px;font-weight:600;margin:0 0 12px}.download-buttons{display:flex;gap:8px}@media(max-width:1200px){.merge-container{padding:24px 20px}}@media(max-width:900px){.upload-grid{grid-template-columns:1fr}.join-type-grid{grid-template-columns:repeat(2,1fr)}.summary-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:640px){.merge-container{padding:16px}.summary-grid{grid-template-columns:repeat(2,1fr)}.key-selection-grid{flex-direction:column}.key-equals{padding:0;transform:rotate(90deg)}.sheet-tabs{overflow-x:auto}}.auth-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 0}.skeleton-container{width:100%;max-width:800px}.skeleton-header{height:24px;width:200px;background:linear-gradient(90deg,#e5e5e5 25%,#f0f0f0,#e5e5e5 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px;margin-bottom:24px}.skeleton-upload-area{height:120px;background:linear-gradient(90deg,#e5e5e5 25%,#f0f0f0,#e5e5e5 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px;margin-bottom:16px}.skeleton-button{height:44px;width:140px;background:linear-gradient(90deg,#e5e5e5 25%,#f0f0f0,#e5e5e5 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:6px}
