*{margin:0;padding:0;box-sizing:border-box}.login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#4472c4,#1a1a2e);padding:20px}.login-card{background:#fff;border-radius:16px;padding:40px;box-shadow:0 10px 40px #0003;max-width:440px;width:100%;text-align:center}.login-header h1{font-size:26px;margin-bottom:6px;color:#1a1a2e}.login-header .subtitle{color:#666;font-size:14px;margin-bottom:24px}.login-body p{color:#555;margin-bottom:20px}.btn-google-login{display:inline-flex;align-items:center;justify-content:center;padding:12px 28px;background:#fff;color:#1a1a2e;border:2px solid #ddd;border-radius:10px;text-decoration:none;font-size:15px;font-weight:600;transition:all .15s;cursor:pointer;width:100%;max-width:320px}.btn-google-login:hover{border-color:#4472c4;box-shadow:0 4px 12px #4472c433;transform:translateY(-1px)}.login-error{background:#fee2e2;color:#991b1b;padding:10px 14px;border-radius:8px;margin-bottom:16px;font-size:13px}.login-footer{margin-top:24px;padding-top:16px;border-top:1px solid #eee}.login-footer small{color:#888;font-size:12px}.login-spinner{width:40px;height:40px;border:4px solid #f0f0f0;border-top-color:#4472c4;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}.user-badge{position:absolute;top:20px;right:20px}.user-badge-btn{display:flex;align-items:center;gap:8px;padding:6px 14px 6px 6px;background:#fff;border:1px solid #e0e0e0;border-radius:24px;cursor:pointer;font-size:13px;color:#333;transition:all .15s}.user-badge-btn:hover{border-color:#4472c4;box-shadow:0 2px 6px #00000014}.user-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover}.user-avatar-text{width:28px;height:28px;border-radius:50%;background:#4472c4;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}.user-email{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu{position:absolute;top:100%;right:0;margin-top:8px;background:#fff;border:1px solid #e0e0e0;border-radius:10px;box-shadow:0 8px 20px #0000001a;min-width:220px;z-index:10}.user-menu-info{padding:14px;border-bottom:1px solid #eee;font-size:13px}.user-menu-email{color:#888;font-size:12px;margin-top:2px;overflow:hidden;text-overflow:ellipsis}.user-menu-logout{width:100%;padding:12px 14px;background:transparent;border:none;text-align:left;cursor:pointer;font-size:13px;color:#c62828;border-radius:0 0 10px 10px}.user-menu-logout:hover{background:#fce4ec}.session-list{display:flex;flex-direction:column;gap:10px;margin:16px 0}.session-card{text-align:left;padding:14px 16px;background:#fff;border:2px solid #e0e0e0;border-radius:10px;cursor:pointer;transition:all .15s}.session-card:hover{border-color:#4472c4;background:#f0f7ff;transform:translateY(-1px);box-shadow:0 4px 10px #4472c426}.session-card-title{font-weight:600;font-size:15px;color:#1a1a2e;margin-bottom:4px}.session-card-meta{font-size:13px;color:#555;margin-bottom:4px}.session-card-id{font-size:11px;color:#999;font-family:SF Mono,monospace}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f0f2f5;color:#1a1a2e}.app{max-width:1200px;margin:0 auto;padding:20px}header{text-align:center;margin-bottom:24px}header{position:relative}header h1{font-size:28px;color:#1a1a2e}.btn-reset{position:absolute;top:0;right:0;padding:6px 14px;background:#fce4ec;color:#c62828;border:1px solid #f8bbd0;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500}.btn-reset:hover{background:#f8bbd0}.btn-del{padding:4px 10px;background:transparent;color:#c62828;border:1px solid #f8bbd0;border-radius:6px;cursor:pointer;font-size:13px;transition:all .15s}.btn-del:hover{background:#fce4ec}.file-actions{display:flex;align-items:center;gap:8px}.badge-success{background:#4caf50}.badge-warn{background:#ff9800}.badge-progress{background:#2196f3;animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.file-info{display:flex;align-items:center;gap:8px;flex:1;flex-wrap:wrap}.file-name{font-weight:500}.file-done{background:#f1f8e9;border-left:3px solid #4CAF50}.btn-extract-file{padding:6px 14px;background:#4472c4;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;transition:all .15s}.btn-extract-file:hover:not(:disabled){background:#3461b3;transform:translateY(-1px)}.btn-extract-file:disabled{background:#aaa;cursor:not-allowed;opacity:.6}.btn-extract-done{background:#757575}.btn-extract-done:hover:not(:disabled){background:#616161}.current-file{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#e8f5e9;border:1px solid #c8e6c9;border-radius:8px;margin-bottom:12px}.subtitle{color:#666;font-size:14px}.steps{display:flex;justify-content:center;gap:8px;margin-bottom:24px;flex-wrap:wrap}.step-item{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:20px;background:#e0e0e0;font-size:13px;cursor:default;transition:all .2s}.step-item.active{background:#4472c4;color:#fff;font-weight:600}.step-item.done{background:#4caf50;color:#fff;cursor:pointer}.step-num{width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#ffffff4d;font-size:12px;font-weight:700}.card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014}.card h2{font-size:20px;margin-bottom:12px;color:#1a1a2e}.card p{color:#555;margin-bottom:12px}.note{font-size:13px;color:#888}.upload-btn{display:inline-block;padding:12px 24px;background:#4472c4;color:#fff;border-radius:8px;cursor:pointer;font-weight:600;transition:background .2s}.upload-btn:hover{background:#3461b3}.btn-primary{padding:10px 24px;background:#4472c4;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:background .2s}.btn-primary:hover{background:#3461b3}.btn-secondary{padding:10px 24px;background:#e0e0e0;color:#333;border:none;border-radius:8px;cursor:pointer;font-size:14px}.btn-export{padding:10px 20px;background:#4caf50;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600}.btn-export:hover{background:#43a047}.btn-export:disabled{background:#aaa;cursor:not-allowed}.actions{display:flex;gap:12px;margin-top:20px;flex-wrap:wrap}.file-list{margin-top:16px}.file-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#f8f9fa;border-radius:6px;margin-bottom:6px}.badge{background:#4472c4;color:#fff;padding:2px 10px;border-radius:12px;font-size:12px}.total{font-weight:600;margin-top:8px}.progress-box{margin:16px 0}.progress-bar{height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:#4472c4;border-radius:4px;transition:width .3s}.table-wrap{overflow-x:auto;margin-top:12px}table{width:100%;border-collapse:collapse;font-size:13px}th{background:#4472c4;color:#fff;padding:8px 10px;text-align:left;white-space:nowrap;position:sticky;top:0}td{padding:6px 10px;border-bottom:1px solid #eee}tr:hover{background:#f8f9fa}.page-header-row td{background:#d6e4f0;font-weight:600;font-size:13px;color:#1a1a2e;padding:8px 10px}.file-tabs{display:flex;flex-wrap:wrap;gap:6px;margin:12px 0 16px;padding:8px;background:#f5f7fa;border-radius:10px;border:1px solid #e0e0e0}.file-tab{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#fff;border:1px solid #ddd;border-radius:8px;cursor:pointer;font-size:13px;transition:all .15s;max-width:340px}.file-tab:hover{border-color:#4472c4;transform:translateY(-1px);box-shadow:0 2px 6px #4472c426}.file-tab-active{background:#4472c4;color:#fff;border-color:#4472c4;font-weight:600}.file-tab-active:hover{background:#3461b3}.file-tab-done{background:#e8f5e9;border-color:#4caf50;color:#2e7d32}.file-tab-done:hover{border-color:#4caf50}.file-tab-active.file-tab-done{background:#4caf50;color:#fff;border-color:#4caf50}.file-tab-icon{font-size:16px}.file-tab-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.file-tab-stats{font-size:11px;opacity:.85;white-space:nowrap}.file-tab-warn{color:#f57f17;font-weight:600}.file-tab-active .file-tab-warn,.file-tab-done .file-tab-warn{color:#ffe082}.btn-verify-file{padding:10px 20px;background:#66bb6a;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600}.btn-verify-file:hover{background:#4caf50}.file-separator-row td{background:linear-gradient(90deg,#1a1a2e,#4472c4);color:#fff;font-weight:700;padding:12px 16px!important;border-top:3px solid #1a1a2e}.file-separator-content{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.file-icon{font-size:20px}.file-sep-name{font-size:15px;letter-spacing:.3px}.file-sep-meta{font-size:12px;font-weight:400;opacity:.9;margin-left:auto}.file-sep-meta .warn{color:#ffe082;font-weight:600}.page-header-row.page-verified td{background:#c8e6c9}.page-header-content{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.page-title{flex:1;min-width:200px}.page-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.sum-ok{background:#c8e6c9;color:#2e7d32;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:600}.sum-short{background:#ffcdd2;color:#c62828;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:600}.sum-over{background:#fff9c4;color:#f57f17;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:600}.btn-add-row{padding:4px 10px;background:#fff;color:#4472c4;border:1px solid #4472C4;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600}.btn-add-row:hover{background:#e3f2fd}.btn-verify{padding:4px 12px;background:#ffb74d;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600}.btn-verify:hover{background:#ffa726}.btn-unverify{padding:4px 12px;background:#4caf50;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600}.btn-unverify:hover{background:#43a047}.btn-confirm-all{padding:10px 24px;background:#ffb74d;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600}.btn-confirm-all:hover{background:#ffa726}.btn-del-row{padding:2px 8px;background:transparent;color:#c62828;border:1px solid transparent;border-radius:4px;cursor:pointer;font-size:12px;opacity:.5}.btn-del-row:hover{opacity:1;border-color:#f8bbd0;background:#fce4ec}.verified-row{background:#f1f8e9}.manual-row{border-left:3px solid #FFB74D}.row-check{color:#4caf50;font-weight:700}.row-manual{color:#ffb74d;font-weight:700}.bank-short-badge{display:inline-block;padding:2px 8px;border-radius:10px;color:#fff;font-size:11px;font-weight:700;letter-spacing:.3px}.sheet-card{cursor:pointer;transition:all .15s;position:relative}.sheet-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.sheet-card-active{background:#e3f2fd;border-color:#4472c4;box-shadow:0 2px 8px #4472c44d}.preview-title{margin-top:16px;margin-bottom:8px;color:#4472c4;font-size:15px}.excel-preview-section{margin-top:16px}.reconcile-help{background:#fff8e1;padding:12px 16px;border-left:3px solid #FFC107;border-radius:6px;margin-bottom:16px;font-size:13px;color:#5d4037}.summary.verified-summary{background:linear-gradient(135deg,#66bb6a,#43a047)}.result-select{width:100%;padding:6px 8px;font-size:12px;border:1px solid #ddd;border-radius:6px;background:#fff;cursor:pointer}.result-select:focus{border-color:#4472c4;outline:none}.manual-note-input{width:100%;margin-top:4px;padding:4px 8px;font-size:12px;border:1px solid #FFB74D;border-radius:4px;background:#fff8e1}.confidence-note-small{font-size:11px;color:#ff6f00;margin-top:2px;font-style:italic}.btn-verify-small{padding:5px 12px;background:#ffb74d;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;white-space:nowrap}.btn-verify-small:hover:not(:disabled){background:#ffa726}.btn-verify-small:disabled{background:#bdbdbd;cursor:not-allowed}.btn-unverify-small{padding:5px 12px;background:#4caf50;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;white-space:nowrap}.btn-unverify-small:hover{background:#43a047}.reconcile-table input.amount-edit,.reconcile-table input.date-edit,.reconcile-table input.bank-edit{width:100%;padding:5px 8px;border:1px solid #ddd;border-radius:4px;font-size:13px;background:#fafafa;box-sizing:border-box}.reconcile-table input.amount-edit{text-align:right;font-family:SF Mono,Menlo,monospace;font-weight:600;min-width:90px}.reconcile-table input.date-edit{text-align:center;min-width:80px}.reconcile-table input.bank-edit{text-align:center;font-weight:600;min-width:70px}.reconcile-table input:focus{background:#fff;border-color:#4472c4;outline:none;box-shadow:0 0 0 2px #4472c433}.research-row{margin-top:6px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.btn-research{padding:4px 10px;background:#fff;color:#4472c4;border:1px solid #4472C4;border-radius:6px;cursor:pointer;font-size:11px;font-weight:600;transition:all .15s}.btn-research:hover{background:#e3f2fd}.btn-research-active{background:#ffb74d;color:#fff;border-color:#ffb74d;animation:pulse-research 1.5s ease-in-out infinite}.btn-research-active:hover{background:#ffa726;border-color:#ffa726}@keyframes pulse-research{0%,to{box-shadow:0 0 #ffb74d80}50%{box-shadow:0 0 0 4px #ffb74d00}}.edited-hint{color:#ff6f00;font-size:11px;font-weight:600}.tab-bank{font-weight:600;position:relative}.tab-bank.active{color:#fff;border-color:transparent}.bank-sheet-preview{margin-top:20px;padding:16px;background:#fafafa;border-radius:10px;border:1px solid #eee}.bank-sheet-preview h4{margin-bottom:12px;font-size:14px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.export-section{padding:16px;background:#f8f9fa;border-radius:10px;margin-bottom:16px;border:1px solid #e0e0e0}.export-section h3{font-size:16px;margin-bottom:6px;color:#1a1a2e}.export-section p{font-size:13px;color:#666;margin-bottom:10px}.bank-export-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.btn-export-bank{padding:10px 18px;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:13px;font-weight:700;transition:all .15s}.btn-export-bank:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.btn-export-bank:disabled{opacity:.5;cursor:not-allowed}.export-history{display:flex;flex-direction:column;gap:8px}.export-history-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;flex-wrap:wrap;gap:8px}.export-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:200px}.export-name{font-weight:600;font-size:13px}.export-meta{font-size:11px;color:#888}.btn-download-history{padding:6px 14px;background:#4472c4;color:#fff;border-radius:6px;text-decoration:none;font-size:12px;font-weight:600}.btn-download-history:hover{background:#3461b3}table input{width:100%;min-width:70px;padding:5px 8px;border:1px solid #ddd;border-radius:4px;font-size:13px;background:transparent;box-sizing:border-box}table input:focus{border-color:#4472c4;outline:none;background:#fff}table input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield;text-align:right}table input[type=number]::-webkit-inner-spin-button,table input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.re-table{table-layout:auto}.re-table th:nth-child(1),.re-table td:nth-child(1){width:40px;min-width:40px;text-align:center}.re-table th:nth-child(2),.re-table td:nth-child(2){min-width:130px;width:130px}.re-table td:nth-child(2) input{font-family:SF Mono,Menlo,monospace;font-weight:600;letter-spacing:.3px}.re-table th:nth-child(3),.re-table td:nth-child(3){min-width:110px;width:110px}.re-table td:nth-child(3) input{font-family:SF Mono,Menlo,monospace;font-weight:600}.re-table th:nth-child(4),.re-table td:nth-child(4){min-width:90px;width:90px}.re-table th:nth-child(5),.re-table td:nth-child(5){min-width:90px;width:90px}.re-table td:nth-child(5) input{text-align:center;font-weight:600}.re-table th:nth-child(6),.re-table td:nth-child(6){min-width:90px;width:90px}.re-table th:nth-child(7),.re-table td:nth-child(7){min-width:110px;width:110px}.re-table th:nth-child(8),.re-table td:nth-child(8){min-width:110px;width:110px;font-size:11px}.re-table th:nth-child(9),.re-table td:nth-child(9){min-width:200px}.re-table th:nth-child(10),.re-table td:nth-child(10){width:40px;min-width:40px}.qt-cell{font-size:12px;color:#666}.auto-cell{background:#f0f7ff;font-weight:600;color:#2c5aa0;text-align:center}.bank-name-hint{font-weight:400;font-size:10px;color:#888;margin-top:2px}.ok{color:#4caf50;font-weight:600}.warn{color:#ff9800;font-weight:600}.err{color:#f44336;font-weight:600}.ok-row{background:#f1f8e9}.warn-row{background:#fff8e1}.err-row{background:#fce4ec}.has-re{background:#e8f5e9}.amount{text-align:right;font-family:SF Mono,monospace}.sheet-tabs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:12px}.tab{padding:8px 16px;border:1px solid #ddd;border-radius:6px;background:#fff;cursor:pointer;font-size:13px;transition:all .2s}.tab.active{background:#4472c4;color:#fff;border-color:#4472c4}.tab:hover:not(.active){background:#f0f0f0}.sheet-summary{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}.sheet-card{display:flex;flex-direction:column;padding:12px 16px;background:#f8f9fa;border-radius:8px;border:1px solid #e0e0e0;min-width:120px}.sheet-name{font-weight:700;font-size:16px;color:#4472c4}.sheet-info{font-size:12px;color:#888}.summary-cards{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.summary{flex:1;min-width:100px;padding:16px;border-radius:10px;text-align:center;color:#fff}.summary .num{display:block;font-size:32px;font-weight:700}.summary.ok{background:#4caf50}.summary.warn{background:#ff9800}.summary.err{background:#f44336}.summary.total{background:#4472c4}.error-bar{background:#fce4ec;color:#c62828;padding:10px 16px;border-radius:8px;margin-bottom:16px;display:flex;justify-content:space-between;align-items:center}.error-bar button{background:none;border:none;color:#c62828;font-size:18px;cursor:pointer}.export-actions{justify-content:flex-start;padding-top:16px;border-top:1px solid #eee}@media(max-width:768px){.app{padding:12px}.card{padding:16px}.summary-cards{gap:8px}.summary{min-width:70px;padding:10px}.summary .num{font-size:24px}}.hub-back-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;background:#ecfdf5;color:#047857;border:1px solid #6ee7b7;border-radius:6px;font-size:13px;font-weight:500;text-decoration:none;transition:background .15s}.hub-back-btn:hover{background:#d1fae5}
