.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:12px;padding:40px;max-width:450px;width:100%;position:relative;box-shadow:0 10px 40px #0000004d}.modal-close{position:absolute;top:15px;right:15px;background:none;border:none;font-size:2rem;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover{background:#f0f0f0;color:#333}.modal-content h2{margin:0 0 8px;color:#3a6969;font-size:1.75rem;text-align:center;display:flex;align-items:center;justify-content:center;gap:12px}.modal-logo{height:32px;width:auto;vertical-align:middle}.modal-subtitle{margin:0 0 24px;color:#666;font-size:.95rem;text-align:center}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;color:#3a6969;font-weight:500;font-size:.9rem}.form-group input{width:100%;padding:12px;border:2px solid #E5E5E5;border-radius:6px;font-size:1rem;font-family:inherit;transition:border-color .2s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#5ba4a4}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.error-message{padding:12px;background:#ffe5e5;color:#c33;border-radius:6px;margin-bottom:20px;font-size:.9rem}.modal-content .primary-button{width:100%;margin-bottom:16px}.modal-footer{text-align:center;margin:0;color:#666;font-size:.9rem}.link-button{background:none;border:none;color:#5ba4a4;cursor:pointer;padding:0;font-size:inherit;font-weight:500;text-decoration:underline;transition:color .2s}.link-button:hover{color:#4a8787}.payment-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.payment-modal{background:#fff;border-radius:12px;max-width:500px;width:100%;box-shadow:0 20px 60px #0000004d;position:relative;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.payment-modal__close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;color:#666;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.payment-modal__close:hover{background:#f0f0f0;color:#333}.payment-modal__header{padding:2rem 2rem 1rem;border-bottom:1px solid #e0e0e0}.payment-modal__header h2{margin:0 0 .5rem;color:#3c6d6c;font-size:1.75rem;display:flex;align-items:center;gap:.75rem}.payment-modal__header-logo{height:32px;width:auto}.payment-modal__subtitle{margin:0;color:#666;font-size:.95rem}.payment-modal__content{padding:2rem}.payment-modal__price{text-align:center;margin-bottom:2rem;color:#3c6d6c}.payment-modal__currency{font-size:2rem;font-weight:600;vertical-align:super}.payment-modal__amount{font-size:4rem;font-weight:700;line-height:1}.payment-modal__decimal{font-size:2rem;font-weight:600}.payment-modal__features{margin-bottom:1.5rem}.payment-modal__features h3{margin:0 0 1rem;color:#333;font-size:1.1rem}.payment-modal__features ul{list-style:none;padding:0;margin:0}.payment-modal__features li{padding:.5rem 0;color:#555;font-size:.95rem}.payment-modal__feature-item{display:flex;align-items:flex-start;gap:.625rem}.payment-modal__feature-item svg{flex-shrink:0;margin-top:.1rem}.payment-modal__security-note{display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.payment-modal__security{background:#f8f8f8;padding:1rem;border-radius:8px;text-align:center}.payment-modal__security p{margin:.25rem 0;color:#666;font-size:.9rem}.payment-modal__note{font-size:.8rem!important;color:#999!important}.payment-modal__actions{padding:1.5rem 2rem;border-top:1px solid #e0e0e0;display:flex;gap:1rem;justify-content:flex-end}.payment-modal__button{padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;border:none}.payment-modal__button:disabled{opacity:.6;cursor:not-allowed}.payment-modal__button--secondary{background:#f0f0f0;color:#333}.payment-modal__button--secondary:hover:not(:disabled){background:#e0e0e0}.payment-modal__button--primary{background:#4a8787;color:#fff;display:flex;align-items:center;justify-content:center;gap:.5rem}.payment-modal__button--primary:hover:not(:disabled){background:#3a6767;transform:translateY(-1px);box-shadow:0 4px 12px #4a87874d}.payment-modal__button-icon{height:20px;width:auto}@media(max-width:768px){.payment-modal{max-width:100%;margin:1rem}.payment-modal__header{padding:1.5rem 1.5rem 1rem}.payment-modal__header h2{font-size:1.5rem}.payment-modal__content{padding:1.5rem}.payment-modal__price{margin-bottom:1.5rem}.payment-modal__amount{font-size:3rem}.payment-modal__actions{flex-direction:column-reverse;gap:.75rem}.payment-modal__button{width:100%}}.account-page{position:fixed;top:0;left:0;right:0;bottom:0;min-height:100vh;background:linear-gradient(135deg,#eff6f6,#fff);overflow-y:auto;z-index:1000}.account-header{background:linear-gradient(135deg,#6fafaf,#4a8787);color:#fff;padding:20px 40px;display:flex;justify-content:center;align-items:center;box-shadow:0 2px 8px #0000001a;position:relative}.account-info{text-align:center}.account-header-buttons{position:absolute;top:20px;right:40px;display:flex;gap:10px}@media(max-width:768px){.account-header{flex-direction:column;padding:15px 20px}.account-header-buttons{position:static;margin-top:15px;justify-content:center}.account-info h1{font-size:1.5rem;margin-bottom:4px}.session-card{flex-direction:column;align-items:flex-start;gap:12px;padding:16px}.session-icon{font-size:2rem}.session-details{width:100%}.session-details h3{font-size:1rem}.session-meta{font-size:.85rem}.session-actions{align-self:flex-end;margin-top:-8px}.view-session-button,.export-session-button,.delete-session-button{font-size:1.3rem}.back-button,.logout-button,.desktop-button{font-size:.85rem;padding:6px 12px}.button-text-full{display:none}.button-text-mobile{display:inline}}.back-button,.logout-button,.desktop-button{padding:8px 16px;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.button-text-full{display:inline}.button-text-mobile{display:none}.back-button{background:#fff;color:#4a8787}.back-button:hover{background:#f0f0f0;transform:translateY(-1px)}.logout-button{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3)}.logout-button:hover{background:#ffffff40}.desktop-button{display:inline-flex;align-items:center;padding:8px 16px;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.4)}.desktop-button:hover{background:#ffffff4d;transform:translateY(-1px)}.account-info h1{display:inline-flex;align-items:center;margin:0 0 8px;font-size:1.75rem;font-weight:600}.user-email{margin:0;font-size:1rem;opacity:.95}.account-content{max-width:900px;margin:40px auto;padding:0 20px}.sessions-section h2{color:#3a6969;margin-bottom:24px;font-size:1.5rem}.loading{text-align:center;color:#666;padding:40px;font-size:1.1rem}.error-box{background:#ffe5e5;color:#c33;padding:24px;border-radius:8px;text-align:center}.error-box p{margin:0 0 16px}.retry-button{background:#c33;color:#fff;border:none;padding:10px 24px;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .2s}.retry-button:hover{background:#a22}.empty-state{text-align:center;padding:60px 20px;color:#999}.empty-state p{margin:0;font-size:1.25rem}.empty-subtitle{font-size:1rem!important;margin-top:8px!important}.sessions-list{display:flex;flex-direction:column;gap:16px}.session-card{background:#fff;border:1px solid #E5E5E5;border-radius:8px;padding:20px;display:flex;gap:20px;align-items:flex-start;transition:all .2s;box-shadow:0 2px 4px #0000000d}.session-card:hover{border-color:#96c5c5;box-shadow:0 4px 12px #6fafaf26}.session-icon{font-size:2.5rem;flex-shrink:0}.session-details{flex:1}.session-details h3{margin:0 0 8px;color:#3a6969;font-size:1.1rem}.session-meta{margin:0 0 12px;color:#666;font-size:.9rem}.session-status{display:inline-block;padding:4px 12px;border-radius:12px;font-size:.85rem;font-weight:500;text-transform:capitalize}.status-uploaded{background:#e3f2fd;color:#1976d2}.status-categorized{background:#e8f5e9;color:#388e3c}.status-exported{background:#f3e5f5;color:#7b1fa2}.status-unknown{background:#f5f5f5;color:#757575}.session-actions{display:flex;gap:8px;align-items:center;margin-left:auto}.view-session-button{background:transparent;border:none;font-size:1.5rem;cursor:pointer;padding:8px;opacity:.5;transition:all .2s}.view-session-button:hover{opacity:1;transform:scale(1.1)}.export-session-button{background:transparent;border:none;font-size:1.5rem;cursor:pointer;padding:8px;opacity:.5;transition:all .2s}.export-session-button:hover{opacity:1;transform:scale(1.1)}.delete-session-button{background:transparent;border:none;font-size:1.5rem;cursor:pointer;padding:8px;opacity:.5;transition:all .2s}.delete-session-button:hover{opacity:1;transform:scale(1.1)}.desktop-app-promo{margin-top:40px;padding:32px;background:linear-gradient(135deg,#f0f9f9,#e3f4f4);border-radius:12px;border:2px solid #6FAFAF;box-shadow:0 4px 12px #6fafaf1a}.promo-header{display:flex;align-items:center;gap:20px;margin-bottom:28px;justify-content:center}.promo-logo{height:48px;width:auto;flex-shrink:0}.promo-header h2{color:#2c5a5a;margin:0 0 8px;font-size:1.6rem}.promo-header p{color:#5a8787;margin:0;font-size:1rem}.comparison-table{overflow-x:auto;margin:24px 0}.comparison-table table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #00000014}.comparison-table th,.comparison-table td{padding:12px 16px;text-align:left;border-bottom:1px solid #E5F2F2}.comparison-table th{background:linear-gradient(135deg,#6fafaf,#5ba4a4);color:#fff;font-weight:600;font-size:.9rem;text-align:center}.comparison-table th:first-child{text-align:left}.comparison-table td{color:#333;font-size:.9rem}.comparison-table td:first-child{font-weight:500;color:#2c5a5a}.comparison-table td:not(:first-child){text-align:center}.comparison-table tbody tr:hover{background:#f8fcfc}.comparison-table tbody tr:last-child td{border-bottom:none}.promo-actions{text-align:center;margin-top:24px}.download-desktop-button{display:inline-block;background:linear-gradient(135deg,#6fafaf,#5ba4a4);color:#fff;padding:14px 32px;border-radius:8px;font-weight:600;font-size:1.05rem;text-decoration:none;box-shadow:0 4px 12px #6fafaf4d;transition:all .3s ease;border:none;cursor:pointer}.download-desktop-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #6fafaf66;background:linear-gradient(135deg,#5ba4a4,#4a8787)}.promo-subtitle{margin-top:12px;color:#5a8787;font-size:.85rem}@media(max-width:768px){.desktop-app-promo{padding:20px}.promo-header{flex-direction:column;text-align:center;gap:12px}.promo-logo{height:40px}.promo-header h2{font-size:1.3rem}.comparison-table{font-size:.85rem}.comparison-table th,.comparison-table td{padding:8px 10px}.download-desktop-button{padding:12px 24px;font-size:.95rem}}.danger-zone{margin-top:60px;padding:24px;border:2px solid #FFE5E5;border-radius:8px;background:#fff9f9}.danger-zone h3{color:#c33;margin:0 0 12px;font-size:1.1rem}.danger-zone p{color:#666;margin:0 0 20px;font-size:.95rem}.delete-account-button{background:#dc3545;color:#fff;border:none;padding:10px 24px;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .2s}.delete-account-button:hover{background:#c82333;transform:translateY(-1px);box-shadow:0 2px 8px #dc35454d}.legal-page{max-width:900px;margin:0 auto;padding:2rem;background:#fff;min-height:100vh}.legal-page .back-button{background:#6fafaf;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;margin-bottom:2rem;transition:background .3s ease}.legal-page .back-button:hover{background:#5ba4a4}.legal-nav{display:flex;gap:.75rem;justify-content:center;margin-bottom:2rem;padding:0;background:transparent;border-radius:0;flex-wrap:wrap}.legal-nav button{background:#6fafaf;color:#fff;border:none;padding:.6rem 1.2rem;border-radius:5px;font-size:.95rem;cursor:pointer;transition:background .2s ease,color .2s ease;flex:0 1 auto;font-weight:500;letter-spacing:.3px}.legal-nav button:hover{background:#5ba4a4}.legal-nav button.active{background:#4a8787;color:#fff}.legal-content{line-height:1.8;color:#333}.legal-content h1{display:flex;align-items:center;justify-content:center;width:100%;font-size:2.5rem;color:#6fafaf;margin-bottom:.5rem;border-bottom:3px solid #6FAFAF;padding-bottom:.5rem}.legal-content .last-updated{color:#666;font-style:italic;margin-bottom:2rem;text-align:center}.legal-content section{margin-bottom:2.5rem}.legal-content h2{font-size:1.75rem;color:#4a8787;margin-top:2rem;margin-bottom:1rem;border-left:4px solid #6FAFAF;padding-left:1rem}.legal-content h3{font-size:1.25rem;color:#5ba4a4;margin-top:1.5rem;margin-bottom:.75rem}.legal-content p{margin-bottom:1rem;text-align:justify}.legal-content ul{margin:1rem 0 1rem 2rem;list-style-type:disc}.legal-content ul li{margin-bottom:.5rem}.legal-content a{color:#6fafaf;text-decoration:underline;transition:color .3s ease}.legal-content a:hover{color:#4a8787}.legal-content strong{font-weight:600;color:#4a8787}.legal-footer{background:#f8f9fa;border-left:4px solid #6FAFAF;padding:1.5rem;margin-top:3rem;border-radius:6px}.legal-footer p{margin:0;font-weight:500;color:#4a8787}@media(max-width:768px){.legal-page{padding:1rem}.legal-content h1{font-size:1.5rem;flex-direction:column;gap:.5rem}.legal-content h1 img{margin-right:0!important;margin-top:0!important}.legal-content h2{font-size:1.5rem}.legal-content h3{font-size:1.1rem}.legal-content p{text-align:left}.legal-content ul{margin-left:1.5rem}}@media print{.legal-page .back-button{display:none}.legal-page{padding:0}.legal-content a{color:#000;text-decoration:underline}}.amount-display{display:inline-flex;align-items:baseline;gap:2px;font-size:15px;line-height:1.4;font-variant-numeric:tabular-nums;letter-spacing:-.01em}.amount-display__symbol{font-size:13px;opacity:.8;font-weight:500}.amount-display__value{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.amount-display--uncategorized{font-style:italic;opacity:.85}.amount-display:hover{opacity:.9;transition:opacity .15s ease}.amount-display--large{font-size:18px}.amount-display--large .amount-display__symbol{font-size:15px}.amount-display--compact{font-size:14px;gap:1px}.amount-display--compact .amount-display__symbol{font-size:12px}.merchant-name{display:inline-flex;align-items:center;gap:8px;font-size:15px;line-height:1.5;color:#1f2937;font-weight:500}.merchant-name__icon{flex-shrink:0;color:#6b7280;opacity:.7}.merchant-name__text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.merchant-name--editable{cursor:not-allowed;opacity:.85}.merchant-name--editable .merchant-name__text{border-bottom:1px dashed transparent}.merchant-name__edit-hint{font-size:11px;color:#9ca3af;font-weight:400;font-style:italic;margin-left:4px}.merchant-name:not(.merchant-name--editable):hover{color:#111827}.merchant-name:not(.merchant-name--editable):hover .merchant-name__icon{opacity:1;color:#4b5563}.merchant-name--compact{font-size:14px;gap:6px}.merchant-name--compact .merchant-name__icon{width:14px;height:14px}.merchant-name--bold .merchant-name__text{font-weight:600}.merchant-name--muted{color:#6b7280;font-weight:400}.merchant-name--muted .merchant-name__icon{opacity:.5}.category-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:12px;font-weight:500;font-size:13px;line-height:1.2;white-space:nowrap;transition:all .15s ease;-webkit-user-select:none;user-select:none;border:1px solid transparent}.category-badge--small{padding:2px 6px;font-size:11px;border-radius:8px;gap:2px}.category-badge--medium{padding:4px 10px;font-size:13px;border-radius:12px;gap:4px}.category-badge--large{padding:6px 12px;font-size:14px;border-radius:14px;gap:5px}.category-badge--income{background-color:#28a7451a;color:#28a745;border-color:#28a74533}.category-badge--income .category-badge__icon{color:#28a745}.category-badge--expense{background-color:#dc35451a;color:#dc3545;border-color:#dc354533}.category-badge--expense .category-badge__icon{color:#dc3545}.category-badge--uncategorized{background-color:#6c757d1a;color:#6c757d;border-color:#6c757d33}.category-badge--uncategorized .category-badge__icon{color:#6c757d}.category-badge--clickable{cursor:pointer}.category-badge--clickable:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.category-badge--clickable:active{transform:translateY(0);box-shadow:0 1px 2px #0000001a}.category-badge--income.category-badge--clickable:hover{background-color:#28a74526;border-color:#28a7454d}.category-badge--income.category-badge--clickable:focus{outline:2px solid rgba(40,167,69,.4);outline-offset:2px}.category-badge--expense.category-badge--clickable:hover{background-color:#dc354526;border-color:#dc35454d}.category-badge--expense.category-badge--clickable:focus{outline:2px solid rgba(220,53,69,.4);outline-offset:2px}.category-badge--uncategorized.category-badge--clickable:hover{background-color:#6c757d26;border-color:#6c757d4d}.category-badge--uncategorized.category-badge--clickable:focus{outline:2px solid rgba(108,117,125,.4);outline-offset:2px}.category-badge__icon{flex-shrink:0;opacity:.8}.category-badge__label{line-height:1}@keyframes badge-appear{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.category-badge{animation:badge-appear .2s ease-out}@media(max-width:768px){.category-badge--medium{padding:3px 8px;font-size:12px}.category-badge--large{padding:5px 10px;font-size:13px}}@media(prefers-color-scheme:dark){.category-badge--income{background-color:#28a74526;border-color:#28a7454d}.category-badge--expense{background-color:#dc354526;border-color:#dc35454d}.category-badge--uncategorized{background-color:#6c757d26;border-color:#6c757d4d}}.transaction-row{padding:16px 20px;border-radius:8px;margin-bottom:12px;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0000000f;position:relative;z-index:1;cursor:pointer;will-change:transform,box-shadow}.transaction-row:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a;z-index:10}.transaction-row--selected{border:2px solid #6FAFAF!important;box-shadow:0 0 0 3px #6fafaf26,0 4px 12px #0000001a;z-index:11;padding:15px 19px}.transaction-row--selected:hover{transform:translateY(-2px);box-shadow:0 0 0 3px #6fafaf33,0 6px 16px #0000001f}.transaction-row__content{display:flex;flex-direction:column;gap:8px}@media(min-width:1024px){.transaction-row__content{display:grid;grid-template-columns:100px 1fr 120px 150px 200px;gap:16px;align-items:center;min-height:40px}}.transaction-row__date{font-size:14px;color:#6c757d;font-weight:500}.transaction-row__merchant-wrapper{min-width:0;overflow:hidden;display:flex;align-items:center;gap:8px}.transaction-row__edited-badge{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;background-color:#28a745;color:#fff;border-radius:50%;cursor:help}.transaction-row__amount{display:flex;align-items:center;justify-content:flex-end}@media(max-width:1023px){.transaction-row__amount{justify-content:flex-start}}.transaction-row__category-wrapper{min-width:0;overflow:visible}.transaction-row__category{font-size:14px;color:#495057;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.transaction-row__category--editable{cursor:pointer;padding:2px;margin:-2px;border-radius:8px;transition:background-color .2s ease;display:flex;align-items:center;gap:4px;max-width:100%}.transaction-row__category--editable:hover{background-color:#00000005}.transaction-row__listbox-container{position:relative;width:100%}.transaction-row:has(.transaction-row__listbox-container>button[aria-expanded=true]){z-index:1001!important}.transaction-row__chevron{opacity:.5;margin-left:4px;transition:transform .2s ease}.transaction-row__category--editable:hover .transaction-row__chevron{opacity:.8}.transaction-row__category-listbox{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:1000;max-height:240px;overflow-y:auto;background:#fff;border:2px solid #6FAFAF;border-radius:6px;box-shadow:0 4px 12px #00000026;padding:2px;outline:none;animation:slideDown .15s ease-out;isolation:isolate}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.transaction-row__category-listbox::-webkit-scrollbar{width:8px}.transaction-row__category-listbox::-webkit-scrollbar-track{background:#f1f3f5;border-radius:4px}.transaction-row__category-listbox::-webkit-scrollbar-thumb{background:#6fafaf;border-radius:4px}.transaction-row__category-listbox::-webkit-scrollbar-thumb:hover{background:#5a9a9a}.transaction-row__category-option{display:flex;align-items:center;justify-content:space-between;padding:5px 8px;border-radius:4px;cursor:pointer;font-size:14px;color:#495057;transition:all .15s ease;-webkit-user-select:none;user-select:none}.transaction-row__category-option--active{background-color:#6fafaf26;color:#2c3e50}.transaction-row__category-option--selected{font-weight:500;color:#5a9a9a}.transaction-row__category-option-label{flex:1}.transaction-row__category-check{color:#6fafaf;flex-shrink:0;margin-left:8px}.transaction-row__notes-wrapper{min-width:0;overflow:hidden}.transaction-row__notes{font-size:14px;color:#6c757d;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.transaction-row__notes-text{font-style:italic;color:#495057}.transaction-row__notes-placeholder{color:#adb5bd;font-style:italic}.transaction-row__notes--editable{cursor:pointer;padding:6px 10px;margin:-6px -10px;border-radius:6px;transition:all .2s ease;display:flex;align-items:center;gap:6px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border:2px solid transparent}.transaction-row__notes--editable:hover{background-color:#6fafaf14;border-color:#6fafaf33}.transaction-row__notes--editable:focus{outline:none;background-color:#6fafaf1f;border-color:#6fafaf4d;box-shadow:0 0 0 2px #6fafaf26}.transaction-row__notes-input{width:100%;padding:6px 10px;border:2px solid #6FAFAF;border-radius:6px;font-size:14px;color:#495057;background-color:#fff;outline:none;box-shadow:0 0 0 3px #6fafaf26;transition:all .2s ease}.transaction-row__notes-input::placeholder{color:#adb5bd;font-style:italic}.transaction-row__notes-input:hover{border-color:#5a9a9a;box-shadow:0 0 0 3px #6fafaf40}.transaction-row__notes-input:focus{border-color:#4a8a8a;box-shadow:0 0 0 4px #6fafaf4d}.transaction-row__notes-input:disabled{opacity:.6;cursor:not-allowed;background-color:#f8f9fa}.transaction-row__spinner{animation:spin 1s linear infinite;flex-shrink:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes input-appear{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.transaction-row__category-select,.transaction-row__notes-input{animation:input-appear .15s ease-out}@keyframes save-success{0%{background-color:#28a74533}to{background-color:transparent}}@media(max-width:767px){.transaction-row{padding:16px}.transaction-row__content{display:flex;flex-direction:column;gap:8px}.transaction-row__date{display:inline-block}.transaction-row__amount{display:inline-block;float:right;font-size:20px}.transaction-row__merchant-wrapper{clear:both;margin-top:4px}.transaction-row__merchant{font-size:16px}.transaction-row__category-wrapper{margin-top:4px}.transaction-row__category{font-size:13px}.transaction-row__notes-wrapper{display:none}}@media(min-width:768px)and (max-width:1023px){.transaction-row{padding:16px 20px}.transaction-row__content{display:grid;grid-template-columns:90px 1fr 110px 140px;gap:12px;align-items:center}.transaction-row__notes-wrapper{display:none}}.transaction-row__hint{font-size:12px;color:#6c757d;text-align:center;margin-top:4px;padding-top:8px;border-top:1px solid rgba(0,0,0,.05)}.transaction-row__hint kbd{background-color:#e9ecef;border:1px solid #DEE2E6;border-radius:3px;padding:2px 6px;font-family:Courier New,monospace;font-size:11px;font-weight:600;color:#495057}.transaction-row--income:hover{background-color:#d4edda!important}.transaction-row--expense:hover{background-color:#f8d7da!important}.transaction-row--uncategorized:hover{background-color:#e2e3e5!important}@media(max-width:1200px){.transaction-row__content{grid-template-columns:90px 1fr 100px 120px 120px 150px 40px;gap:12px}.transaction-row__merchant{font-size:16px}.transaction-row__amount{font-size:20px}}@media(max-width:768px){.transaction-row__content{grid-template-columns:1fr;gap:8px}.transaction-row--editing .transaction-row__content{grid-template-columns:1fr}.transaction-row__amount{text-align:left;font-size:24px}.transaction-row__actions,.transaction-row__hint{grid-column:span 1}}.transaction-list-with-keyboard{width:100%;height:100%;overflow:hidden;display:flex;flex-direction:column}.transaction-list__header{flex-shrink:0;padding:0 0 1rem;border-bottom:1px solid #e5e7eb}.transaction-list__header h3{margin:0 0 .75rem;font-size:1.25rem;font-weight:600;color:#1f2937}.transaction-list__hints{display:flex;flex-direction:column;gap:.5rem}.transaction-list__hint{margin:0;font-size:.875rem;color:#6b7280}.transaction-list__keyboard-hints{display:flex;gap:1rem;flex-wrap:wrap}.keyboard-hint{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;color:#6b7280;padding:.25rem .5rem;background:#f9fafb;border-radius:4px}.keyboard-hint kbd{display:inline-block;padding:.125rem .375rem;font-size:.75rem;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace;font-weight:600;color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:3px;box-shadow:0 1px #0000000d}.transaction-list__body{flex:1;overflow-y:auto;padding:1rem 0 300px}.transaction-list__body::-webkit-scrollbar{width:8px}.transaction-list__body::-webkit-scrollbar-track{background:transparent}.transaction-list__body::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.transaction-list__body::-webkit-scrollbar-thumb:hover{background:#9ca3af}.transaction-list__body--locked{overflow:hidden!important}@media(max-width:768px){.transaction-list__keyboard-hints{display:none}}.transaction-list-with-keyboard:focus-visible{outline:2px solid #6FAFAF;outline-offset:2px}.transaction-list__pagination{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 0 0;border-top:1px solid #e5e7eb;margin-top:auto}.pagination__button{padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.pagination__button:hover:not(:disabled){background:#f9fafb;border-color:#6fafaf;color:#2a4c4c;transform:translateY(-1px)}.pagination__button:active:not(:disabled){transform:translateY(0)}.pagination__button:disabled{opacity:.4;cursor:not-allowed}.pagination__info{display:flex;flex-direction:column;align-items:center;gap:.25rem}.pagination__current{font-size:.875rem;font-weight:600;color:#1f2937}.pagination__range{font-size:.75rem;color:#6b7280}@media(max-width:768px){.transaction-list__pagination{flex-direction:column;gap:.75rem}.pagination__button{width:100%}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;font-size:1rem;line-height:1.5;color:#212529;background-color:#fff;min-height:100vh}button{font-family:inherit;font-size:inherit;line-height:inherit;cursor:pointer;border:none;background:none;-webkit-tap-highlight-color:transparent}button:focus,button:active{outline:none}input,textarea,select{font-family:inherit;font-size:inherit;line-height:inherit}a{text-decoration:none;color:inherit}ul,ol{list-style:none}img{max-width:100%;height:auto;display:block}.hidden{display:none!important}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.gap-xs{gap:.25rem}.gap-sm{gap:.5rem}.gap-md{gap:1rem}.gap-lg{gap:1.5rem}.gap-xl{gap:2rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-base{font-size:1rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.375rem}.text-2xl{font-size:1.5rem}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-primary{color:#212529}.text-secondary{color:#6c757d}.text-tertiary{color:#adb5bd}.text-success{color:#28a745}.text-danger{color:#dc3545}.text-warning{color:#ffc107}.text-info{color:#17a2b8}.bg-white{background-color:#fff}.bg-primary{background-color:#6fafaf}.bg-secondary{background-color:#f8f9fa}.bg-success{background-color:#28a745}.bg-danger{background-color:#dc3545}.p-xs{padding:.25rem}.p-sm{padding:.5rem}.p-md{padding:1rem}.p-lg{padding:1.5rem}.p-xl{padding:2rem}.m-xs{margin:.25rem}.m-sm{margin:.5rem}.m-md{margin:1rem}.m-lg{margin:1.5rem}.m-xl{margin:2rem}.rounded-sm{border-radius:.25rem}.rounded{border-radius:.375rem}.rounded-md{border-radius:.5rem}.rounded-lg{border-radius:.75rem}.rounded-full{border-radius:9999px}.shadow-sm{box-shadow:0 1px 2px #0000000d}.shadow{box-shadow:0 1px 3px #0000001a}.shadow-md{box-shadow:0 4px 6px #0000001a}.shadow-lg{box-shadow:0 10px 15px #0000001a}.shadow-xl{box-shadow:0 20px 25px #00000026}.w-full{width:100%}.w-auto{width:auto}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.transition{transition:all .2s ease}.transition-fast{transition:all .15s ease}.transition-slow{transition:all .3s ease}*:focus-visible{outline:2px solid #6FAFAF;outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.progress-tracker{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 8px #00000014;border:1px solid #e5e7eb;transition:all .3s ease}.progress-tracker.complete{border-color:#6fafaf;background:linear-gradient(135deg,#f0fdf9,#e0f2f2);box-shadow:0 4px 12px #6fafaf26}.progress-tracker__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.progress-tracker__title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;color:#374151}.icon-target{color:#6fafaf}.icon-complete{color:#6fafaf;animation:celebrate .6s ease-in-out}@keyframes celebrate{0%,to{transform:scale(1)}50%{transform:scale(1.2) rotate(10deg)}}.progress-tracker__stats{display:flex;align-items:baseline;gap:.25rem;font-weight:600}.stat-current{font-size:1.5rem;color:#6fafaf;transition:all .3s ease}.progress-tracker.complete .stat-current{color:#6fafaf}.stat-separator{font-size:1.25rem;color:#9ca3af;margin:0 .125rem}.stat-total{font-size:1.25rem;color:#6b7280}.stat-label{font-size:.875rem;color:#9ca3af;margin-left:.25rem;font-weight:500}.progress-tracker__bar-container{width:100%;height:12px;background:#e5e7eb;border-radius:9999px;overflow:hidden;position:relative}.progress-tracker__bar-fill{height:100%;background:linear-gradient(90deg,#6fafaf,#5a9a9a);border-radius:9999px;transition:width .6s cubic-bezier(.4,0,.2,1);position:relative;display:flex;align-items:center;justify-content:flex-end;padding-right:.5rem}.progress-tracker.complete .progress-tracker__bar-fill{background:linear-gradient(90deg,#6fafaf,#5a9a9a);animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{opacity:1}50%{opacity:.8}}.progress-tracker__percentage{font-size:.75rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2)}.progress-tracker__remaining{margin-top:.75rem;font-size:.875rem;color:#6b7280;text-align:center}.progress-tracker__celebration{margin-top:.75rem;padding:.75rem;background:#fff;border-radius:8px;font-size:.875rem;color:#5a9a9a;text-align:center;font-weight:500;animation:slideDown .4s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:640px){.progress-tracker{padding:1rem}.progress-tracker__header{flex-direction:column;align-items:flex-start;gap:.75rem}.progress-tracker__title{font-size:.875rem}.stat-current{font-size:1.25rem}.stat-total{font-size:1rem}}.running-totals{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 8px #00000014;border:1px solid #e5e7eb}.running-totals__title{font-size:1rem;font-weight:600;color:#374151;margin:0 0 1rem}.running-totals__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.total-card{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border-radius:8px;padding:1rem;border:2px solid transparent;transition:all .3s ease}.total-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.total-card--income{border-color:#d1fae5;background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.total-card--expense{border-color:#fecaca;background:linear-gradient(135deg,#fef2f2,#fee2e2)}.total-card--net.positive{border-color:#d1fae5;background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.total-card--net.negative{border-color:#fecaca;background:linear-gradient(135deg,#fef2f2,#fee2e2)}.total-card__header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.total-card__icon{flex-shrink:0}.total-card--income .total-card__icon{color:#059669}.total-card--expense .total-card__icon{color:#dc2626}.total-card--net.positive .total-card__icon{color:#059669}.total-card--net.negative .total-card__icon{color:#dc2626}.total-card__label{font-size:.875rem;font-weight:500;color:#6b7280}.total-card__amount{font-size:1.5rem;font-weight:700;transition:all .3s ease;font-variant-numeric:tabular-nums}.total-card--income .total-card__amount{color:#059669}.total-card--expense .total-card__amount{color:#dc2626}.total-card--net.positive .total-card__amount{color:#059669}.total-card--net.negative .total-card__amount{color:#dc2626}@keyframes flash{0%,to{opacity:1}50%{opacity:.7}}.total-card__amount.updating{animation:flash .5s ease-in-out}@media(max-width:1024px){.running-totals__grid{grid-template-columns:repeat(2,1fr)}.total-card:last-child{grid-column:1 / -1}}@media(max-width:640px){.running-totals{padding:1rem}.running-totals__grid{grid-template-columns:1fr;gap:.75rem}.total-card{padding:.875rem}.total-card__amount{font-size:1.25rem}.total-card:last-child{grid-column:auto}}.context-panel{display:flex;flex-direction:column;height:100%;background:var(--color-background-alt, #f9fafb)}.context-panel__header{padding:0 0 16px;border-bottom:2px solid var(--color-border, #e5e7eb)}.context-panel__title{display:flex;align-items:center;gap:8px;font-size:20px;font-weight:600;color:#1f2937;margin:0 0 4px}.context-panel__title svg{color:#6fafaf;stroke-width:2.5}.context-panel__subtitle{font-size:14px;color:#6b7280;margin:0}.context-panel__content{flex:1;overflow-y:auto;overflow-x:hidden;padding:24px 0}.context-panel__content>*{animation:fadeInSlideUp .3s cubic-bezier(.4,0,.2,1)}@keyframes fadeInSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.context-panel__empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:48px 16px;min-height:300px}.context-panel__empty-state svg{color:#d1d5db;margin-bottom:16px}.context-panel__empty-state h4{font-size:16px;font-weight:600;color:#374151;margin:0 0 8px}.context-panel__empty-state p{font-size:14px;color:#6b7280;margin:0;max-width:280px;line-height:1.5}.context-panel__new-merchant{background:linear-gradient(135deg,#6fafaf14,#5a9a9a14);border:2px dashed rgba(111,175,175,.3);border-radius:12px;padding:24px;text-align:center;overflow:hidden}.context-panel__new-merchant-icon{display:flex;justify-content:center;margin-bottom:12px}.context-panel__new-merchant-icon svg{color:#6fafaf}.context-panel__new-merchant-title{font-size:16px;font-weight:600;color:#1f2937;margin:0 0 8px}.context-panel__new-merchant-text{font-size:14px;color:#4b5563;margin:0 0 20px;line-height:1.6;word-break:break-word}.context-panel__common-categories{width:100%;margin-top:16px}.context-panel__common-categories-title{font-size:13px;font-weight:600;color:#6b7280;margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}.context-panel__common-categories-list{display:flex;flex-direction:column;gap:8px}.context-panel__common-category-button{width:100%;display:flex;align-items:center;justify-content:space-between;background:var(--color-background-alt, #f9fafb);border:1px solid var(--color-border, #e5e7eb);border-radius:6px;padding:10px 12px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-family:inherit}.context-panel__common-category-button:hover:not(.disabled){background:#6fafaf14;border-color:#6fafaf;transform:scale(1.02)}.context-panel__common-category-button:active:not(.disabled){transform:scale(.98)}.context-panel__common-category-button.disabled{opacity:.5;cursor:not-allowed}.context-panel__common-category-name{font-size:13px;font-weight:500;color:#1f2937}.context-panel__common-category-count{font-size:12px;color:#6b7280;font-weight:500}.context-panel__suggestions{display:flex;flex-direction:column;gap:20px;overflow:hidden}.context-panel__history{background:linear-gradient(135deg,#6fafaf14,#5a9a9a14);border-left:4px solid #6FAFAF;border-radius:8px;padding:16px;overflow:hidden}.context-panel__history-text{font-size:14px;color:#4b5563;margin:0 0 12px;line-height:1.5;word-break:break-word}.context-panel__history-text strong{color:#1f2937;font-weight:600}.context-panel__top-suggestion{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}.context-panel__category-badge{background:#6fafaf;color:#fff;padding:4px 12px;border-radius:6px;font-size:13px;font-weight:600;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis}.context-panel__confidence-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;white-space:nowrap;flex-shrink:0}.context-panel__confidence-badge--high{background:#22c55e26;color:#15803d}.context-panel__confidence-badge--medium{background:#fbbf2426;color:#b45309}.context-panel__confidence-badge--low{background:#9ca3af26;color:#4b5563}.context-panel__history-detail{font-size:13px;color:#6b7280;margin:0}.context-panel__apply-section{display:flex;flex-direction:column;gap:12px}.context-panel__apply-button{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,#6fafaf,#5a9a9a);color:#fff;border:none;border-radius:8px;padding:12px 20px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #6fafaf33}.context-panel__apply-button:hover:not(:disabled){background:linear-gradient(135deg,#5a9a9a,#4a8585);box-shadow:0 4px 8px #6fafaf4d;transform:translateY(-2px) scale(1.02)}.context-panel__apply-button:active:not(:disabled){transform:translateY(0) scale(.98);box-shadow:0 2px 4px #6fafaf33}.context-panel__apply-button:disabled{opacity:.7;cursor:not-allowed}.context-panel__apply-button--applying{animation:pulse 1.5s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.context-panel__apply-button svg{flex-shrink:0}.context-panel__keyboard-hint{margin:0;font-size:12px;color:#6b7280;text-align:center}.context-panel__keyboard-hint kbd{display:inline-block;padding:2px 6px;font-size:11px;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace;font-weight:600;color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:3px;box-shadow:0 1px #0000000d}.context-panel__alternatives{background:var(--color-background, #ffffff);border:1px solid var(--color-border, #e5e7eb);border-radius:8px;padding:16px}.context-panel__alternatives-title{font-size:13px;font-weight:600;color:#6b7280;margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}.context-panel__alternatives-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.context-panel__alternative-item{margin:0}.context-panel__alternative-button{width:100%;display:flex;align-items:center;justify-content:space-between;background:var(--color-background-alt, #f9fafb);border:1px solid var(--color-border, #e5e7eb);border-radius:6px;padding:10px 12px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-family:inherit}.context-panel__alternative-button:hover{background:#6fafaf14;border-color:#6fafaf;transform:scale(1.02)}.context-panel__alternative-button:active{transform:scale(.98)}.context-panel__alternative-category{font-size:13px;font-weight:500;color:#1f2937}.context-panel__alternative-confidence{font-size:12px;color:#6b7280;font-weight:500}.context-panel__placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:32px 16px;min-height:400px}.context-panel__placeholder-icon{width:80px;height:80px;background:linear-gradient(135deg,#6fafaf1a,#5a9a9a1a);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:20px}.context-panel__placeholder-icon svg{color:#6fafaf}.context-panel__placeholder-title{font-size:18px;font-weight:600;color:#1f2937;margin:0 0 8px}.context-panel__placeholder-text{font-size:14px;color:#6b7280;margin:0 0 16px}.context-panel__feature-list{list-style:none;padding:0;margin:0 0 24px;text-align:left;max-width:280px}.context-panel__feature-list li{display:flex;align-items:center;gap:8px;padding:8px 0;font-size:14px;color:#374151}.context-panel__feature-list li svg{color:#6fafaf;flex-shrink:0}.context-panel__progress-note{background:linear-gradient(135deg,#6fafaf1a,#5a9a9a26);border:1px solid rgba(111,175,175,.3);border-radius:8px;padding:16px;font-size:14px;color:#1f2937;max-width:320px;line-height:1.6}.context-panel__next-step{color:#6fafaf;font-weight:500}.context-panel__footer{padding:16px 0 0;border-top:1px solid var(--color-border, #e5e7eb)}.context-panel__hint{display:flex;align-items:center;gap:8px;font-size:13px;color:#6b7280;margin:0;line-height:1.5}.context-panel__hint svg{color:#9ca3af;flex-shrink:0}@media(max-width:767px){.context-panel{background:var(--color-background, #ffffff)}.context-panel__header{padding:0 0 12px}.context-panel__content{padding:16px 0}.context-panel__placeholder{padding:24px 8px;min-height:300px}.context-panel__placeholder-icon{width:64px;height:64px}.context-panel__placeholder-icon svg{width:40px;height:40px}.context-panel__feature-list{font-size:13px}.context-panel__progress-note{padding:12px;font-size:13px}}.context-panel__content::-webkit-scrollbar{width:8px}.context-panel__content::-webkit-scrollbar-track{background:transparent}.context-panel__content::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.context-panel__content::-webkit-scrollbar-thumb:hover{background:#9ca3af}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.context-panel__placeholder{animation:fadeIn .5s ease-out}.context-panel__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 16px;min-height:300px;animation:fadeIn .2s ease-out}.context-panel__loading p{font-size:14px;color:#6b7280;margin:16px 0 0}.context-panel__loading-spinner{width:40px;height:40px;border:3px solid rgba(111,175,175,.2);border-top-color:#6fafaf;border-radius:50%;animation:spin .8s linear infinite}.context-panel__button-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@media(prefers-reduced-motion:reduce){.context-panel__placeholder{animation:none}}.mobile-sheet__backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:998;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-sheet{position:fixed;left:0;right:0;bottom:0;max-height:70vh;background:#fff;border-radius:20px 20px 0 0;box-shadow:0 -4px 24px #00000026;z-index:999;transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);display:flex;flex-direction:column;overflow:hidden;touch-action:pan-y}.mobile-sheet--open{transform:translateY(0)}.mobile-sheet__header{padding:12px 20px 8px;border-bottom:1px solid #E5E5E5;background:#f8fafa;cursor:grab;user-select:none;-webkit-user-select:none;touch-action:none}.mobile-sheet__header:active{cursor:grabbing}.mobile-sheet__handle{width:40px;height:4px;background:#cbd5e0;border-radius:2px;margin:0 auto 12px}.mobile-sheet__title{font-size:1.1rem;font-weight:600;color:#2c5a5a;margin:0;text-align:center}.mobile-sheet__merchant{padding:16px 20px;background:linear-gradient(135deg,#f0f9f9,#e3f4f4);border-bottom:2px solid #6FAFAF;display:flex;justify-content:space-between;align-items:center;gap:12px}.mobile-sheet__merchant-name{font-weight:600;color:#2c5a5a;font-size:1rem;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-sheet__merchant-amount{font-weight:700;color:#e53e3e;font-size:1.1rem;flex-shrink:0}.mobile-sheet__content{flex:1;overflow-y:auto;padding:20px;-webkit-overflow-scrolling:touch}.mobile-sheet__new-merchant{text-align:center;padding:32px 20px;color:#5a8787}.mobile-sheet__icon{display:flex;align-items:center;justify-content:center;margin-bottom:16px}.mobile-sheet__new-merchant h4{color:#2c5a5a;margin:0 0 12px;font-size:1.2rem}.mobile-sheet__new-merchant p{margin:0;font-size:.95rem;line-height:1.5}.mobile-sheet__top-suggestion{margin-bottom:24px}.mobile-sheet__suggestion-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.mobile-sheet__label{font-weight:600;color:#5a8787;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.mobile-sheet__confidence{font-size:.75rem;font-weight:600;padding:4px 10px;border-radius:12px;text-transform:uppercase;letter-spacing:.3px}.mobile-sheet__confidence--high{background:#c6f6d5;color:#22543d}.mobile-sheet__confidence--medium{background:#fefcbf;color:#744210}.mobile-sheet__confidence--low{background:#e2e8f0;color:#4a5568}.mobile-sheet__apply-button{width:100%;min-height:56px;padding:16px 20px;background:linear-gradient(135deg,#6fafaf,#5a9999);color:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:600;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #6fafaf40;-webkit-tap-highlight-color:transparent}.mobile-sheet__apply-button:active{transform:scale(.98);box-shadow:0 2px 8px #6fafaf4d}.mobile-sheet__category{flex:1;text-align:left}.mobile-sheet__apply-icon{font-size:1.5rem;margin-left:12px}.mobile-sheet__suggestion-meta{margin-top:8px;font-size:.85rem;color:#718096;text-align:center}.mobile-sheet__alternatives{padding-top:20px;border-top:2px dashed #E2E8F0}.mobile-sheet__alternatives-label{font-size:.85rem;font-weight:600;color:#718096;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.mobile-sheet__alt-button{width:100%;min-height:52px;padding:14px 16px;background:#fff;border:2px solid #E2E8F0;border-radius:10px;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}.mobile-sheet__alt-button:active{transform:scale(.98);background:#f7fafc;border-color:#6fafaf}.mobile-sheet__alt-category{font-weight:600;color:#2c5a5a;font-size:.95rem;text-align:left}.mobile-sheet__alt-meta{font-size:.8rem;color:#718096;white-space:nowrap}.mobile-sheet__content::-webkit-scrollbar{display:none}.mobile-sheet__content{-ms-overflow-style:none;scrollbar-width:none}@media(min-width:769px){.mobile-sheet,.mobile-sheet__backdrop{display:none}}.split-panel-layout{display:flex;width:100%;min-height:600px;height:calc(100vh - 200px);position:relative;background:var(--color-background, #ffffff);border-radius:8px;overflow:hidden}.split-panel-layout__left,.split-panel-layout__right{overflow-y:auto;overflow-x:hidden;padding:24px;transition:width .2s cubic-bezier(.4,0,.2,1);will-change:width}.split-panel-layout__left{border-right:1px solid var(--color-border, #e5e7eb)}.split-panel-layout__right{background:var(--color-background-alt, #f9fafb)}.split-panel-layout__left::-webkit-scrollbar,.split-panel-layout__right::-webkit-scrollbar{width:10px}.split-panel-layout__left::-webkit-scrollbar-track,.split-panel-layout__right::-webkit-scrollbar-track{background:transparent}.split-panel-layout__left::-webkit-scrollbar-thumb,.split-panel-layout__right::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:5px}.split-panel-layout__left::-webkit-scrollbar-thumb:hover,.split-panel-layout__right::-webkit-scrollbar-thumb:hover{background:#9ca3af}.split-panel-layout__divider{width:8px;background:var(--color-border, #e5e7eb);cursor:col-resize;position:relative;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;transition:all .2s cubic-bezier(.4,0,.2,1);will-change:background,transform}.split-panel-layout__divider:hover{background:#6fafaf;transform:scaleX(1.2)}.split-panel-layout__divider:active{background:#5a9a9a;transform:scaleX(1.4)}.split-panel-layout__divider-handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#9ca3af;pointer-events:none;transition:color .2s ease}.split-panel-layout__divider:hover .split-panel-layout__divider-handle{color:#fff}.split-panel-layout--resizing{cursor:col-resize;-webkit-user-select:none;user-select:none}.split-panel-layout--resizing .split-panel-layout__left,.split-panel-layout--resizing .split-panel-layout__right{pointer-events:none;transition:none}.split-panel-layout--resizing .split-panel-layout__divider{background:#6fafaf}@media(max-width:767px){.split-panel-layout--mobile{display:block;height:auto;min-height:400px}.mobile-panel{width:100%;padding:16px;transition:transform .3s ease,opacity .3s ease}.mobile-panel--hidden{transform:translate(-100%);opacity:0;position:absolute;pointer-events:none}.mobile-panel--context{transform:translate(100%);opacity:0;position:absolute;top:0;left:0;right:0;bottom:0;background:var(--color-background, #ffffff);z-index:10;overflow-y:auto}.mobile-panel--context.mobile-panel--visible{transform:translate(0);opacity:1;position:relative}.mobile-panel__header{position:sticky;top:0;background:var(--color-background, #ffffff);padding:12px 0;margin-bottom:16px;border-bottom:1px solid var(--color-border, #e5e7eb);z-index:5}.mobile-panel__back{background:none;border:none;color:#6fafaf;font-size:16px;font-weight:500;cursor:pointer;padding:8px 0;display:flex;align-items:center;gap:4px}.mobile-panel__back:hover{color:#5a9a9a}.floating-context-toggle{position:fixed;bottom:24px;right:24px;background:linear-gradient(135deg,#6fafaf,#5a9a9a);color:#fff;border:none;border-radius:50px;padding:14px 24px;font-size:16px;font-weight:600;display:flex;align-items:center;gap:8px;cursor:pointer;box-shadow:0 4px 12px #6fafaf66;z-index:100;transition:all .3s ease}.floating-context-toggle:hover{transform:translateY(-2px);box-shadow:0 6px 16px #6fafaf80}.floating-context-toggle:active{transform:translateY(0);box-shadow:0 2px 8px #6fafaf66}.floating-context-toggle svg{width:20px;height:20px}}@media(min-width:768px)and (max-width:1024px){.split-panel-layout__left,.split-panel-layout__right{padding:20px}.split-panel-layout{min-height:500px}}.split-panel-layout__divider:focus{outline:2px solid #6FAFAF;outline-offset:2px}@media(prefers-reduced-motion:reduce){.split-panel-layout__left,.split-panel-layout__right,.mobile-panel,.floating-context-toggle{transition:none!important}}@media print{.split-panel-layout{display:block;height:auto}.split-panel-layout__divider,.floating-context-toggle{display:none}.split-panel-layout__left,.split-panel-layout__right{width:100%!important;border:none;page-break-inside:avoid}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#eff6f6;color:#333}.App{max-width:1400px;margin:0 auto;padding:20px;min-height:100vh;display:flex;flex-direction:column}header{background:linear-gradient(135deg,#5a9999,#3a7777);color:#2a4c4c;padding:15px 40px 25px;border-radius:12px;box-shadow:0 4px 8px #5a999940;margin-bottom:30px;position:relative}.header-content{text-align:center}.header-logo{height:1.75rem}.header-brand-text{font-size:1.1rem;text-shadow:0 1px 2px rgba(42,76,76,.4)}@media(min-width:768px){.header-logo{height:2.25rem}.header-brand-text{font-size:1.4rem}}.header-auth{position:absolute;top:20px;right:40px;display:flex;gap:10px}.auth-button,.auth-button-secondary{padding:8px 16px;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.auth-button{background:#fff;color:#4a8787;display:inline-flex;align-items:center;gap:.375rem}.auth-button:hover{background:#f0f0f0;transform:translateY(-1px)}.auth-button-secondary{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3)}.auth-button-secondary:hover{background:#ffffff40}@media(max-width:768px){.header-auth{position:static;margin-top:15px;justify-content:center}.auth-button,.auth-button-secondary{font-size:.85rem;padding:6px 12px}}header h1{font-size:2.5rem;margin-bottom:10px;font-weight:700}header p{font-size:.95rem;opacity:.95;margin-top:0}main{flex:1;background:#fff;padding:40px;border-radius:12px;box-shadow:0 2px 8px #0000001a;min-height:500px}h2{color:#2d3748;margin-bottom:25px;font-size:1.8rem;font-weight:600}.error{background:#fee;border:2px solid #fcc;border-left:5px solid #c33;padding:20px;border-radius:8px;margin-bottom:25px;color:#333;display:block}.error-title{color:#c33;font-size:1.1rem;margin-bottom:10px}.error-title strong{font-weight:700}.error-message{margin:10px 0;color:#333;line-height:1.6}.error-action{margin:15px 0 10px;padding:12px;background:#fff9e6;border-left:3px solid #ffb800;border-radius:4px;color:#333;font-size:.95rem}.error-action strong{color:#c80}.error-dismiss{margin-top:15px;background:#6fafaf;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:.95rem;cursor:pointer;transition:background .3s ease}.error-dismiss:hover{background:#5ba4a4}.error strong{font-weight:600}.upload-section{max-width:600px;margin:0 auto;text-align:center}.file-upload-area{margin:30px 0}.file-label{display:inline-flex;align-items:center;gap:.5rem;padding:12px 28px;background:#5ba4a4;color:#fff;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .3s ease;box-shadow:0 2px 4px #6fafaf4d}.file-label:hover{background:#4a8787;transform:translateY(-2px);box-shadow:0 4px 8px #6fafaf66}.file-input{display:none}.hint{color:#718096;font-size:.95rem;margin-top:15px;font-style:italic}.primary-button{background:#4a8787;color:#fff;border:none;padding:12px 28px;font-size:1rem;border-radius:8px;cursor:pointer;margin:15px 10px;font-weight:600;transition:all .3s ease;box-shadow:0 2px 4px #4a87874d}.button-with-icon{display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.primary-button:hover:not(:disabled){background:#3a6767;transform:translateY(-2px);box-shadow:0 4px 8px #4a878766}.primary-button:disabled{background:#cbd5e0;cursor:not-allowed;transform:none;box-shadow:none}.secondary-button{background:#fff;color:#5ba4a4;border:2px solid #5BA4A4;padding:14px 32px;font-size:1.05rem;border-radius:8px;cursor:pointer;margin:20px 10px;font-weight:600;transition:all .3s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.secondary-button:hover{background:#f7fafc;transform:translateY(-2px)}.button-group{display:flex;justify-content:center;gap:15px;margin-top:30px;flex-wrap:wrap;align-items:center}.button-group .primary-button{padding:14px 32px;font-size:1.05rem;margin:20px 10px}.stats-bar{display:flex;justify-content:center;gap:30px;margin:20px 0 30px;padding:20px;background:#f7fafc;border-radius:8px;flex-wrap:wrap}.stat{text-align:center}.stat-label{display:block;font-size:.9rem;color:#718096;margin-bottom:5px;font-weight:500}.stat-value{display:block;font-size:1.8rem;font-weight:700;color:#2d3748}.stat-value.success{color:#96c5c5}.stat-value.error{color:#dc3545}.transaction-table{margin:30px 0;overflow-x:auto;border-radius:8px;box-shadow:0 1px 3px #0000001a}table{width:100%;border-collapse:collapse;background:#fff}thead{background:#f7fafc;border-bottom:2px solid #e2e8f0}th{padding:15px 12px;text-align:left;font-weight:600;color:#2d3748;font-size:.95rem;text-transform:uppercase;letter-spacing:.5px}td{padding:12px;border-bottom:1px solid #e2e8f0;font-size:.95rem}tr:hover{background:#f7fafc}tr:last-child td{border-bottom:none}td.description{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}td.amount{font-weight:600;color:#2d3748;text-align:right}td.category{font-weight:500;color:#4a5568}.confidence-badge{display:inline-block;padding:4px 10px;border-radius:12px;color:#fff;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.success-section{text-align:center;padding:40px 20px;display:flex;flex-direction:column;align-items:center}.success-icon{font-size:2.2rem;margin-bottom:20px;animation:scaleIn .5s ease}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.success-section h2{color:#6fafaf;font-size:1.6rem;margin-bottom:15px}.success-stats{margin:25px 0;padding:20px;background:#f7fafc;border-radius:8px;display:inline-block}.success-stats p{margin:8px 0;font-size:1.1rem;color:#4a5568}.success-stats strong{color:#2d3748;font-weight:700}.signup-prompt{margin:30px auto;max-width:500px;padding:30px;background:#fff;border:2px solid #6FAFAF;border-radius:12px;box-shadow:0 4px 12px #6fafaf26}.signup-prompt h3{color:#3a6969;margin-bottom:12px;font-size:1.5rem}.signup-prompt p{color:#666;margin-bottom:20px;font-size:1rem}.signup-prompt .primary-button{margin-bottom:12px}.signup-prompt .link-button{background:none;border:none;color:#5ba4a4;cursor:pointer;padding:8px;font-size:.95rem;text-decoration:underline;transition:color .2s}.signup-prompt .link-button:hover{color:#4a8787}.info-box{margin:30px auto;max-width:600px;padding:25px;background:#eff6f6;border-left:4px solid #6FAFAF;border-radius:8px;text-align:left}.info-box h3{color:#2d3748;margin-bottom:15px;font-size:1.2rem}.info-box ul{list-style:none;padding:0;margin:15px 0}.info-box li{padding:8px 0;color:#4a5568;font-size:1rem}.icon-text{display:inline-flex;align-items:center;gap:.5rem}.icon-text--center{justify-content:center}.feature-list__item{display:flex;align-items:flex-start;gap:.625rem}.feature-list__item svg{flex-shrink:0;margin-top:.15rem}.limitations-box{margin-top:1rem;padding:.75rem;background:#fff3cd;border-radius:6px;font-size:.9rem;border:1px solid #ffc107;text-align:left}.limitations-box__heading{margin:0 0 .5rem;font-weight:700;color:#856404}.limitations-box__list{margin:0 0 .5rem;padding-left:1.5rem;color:#856404;line-height:1.6}.limitations-box__tip{margin:0;font-size:.85rem;color:#856404;align-items:flex-start}.limitations-box__tip svg{flex-shrink:0;margin-top:.1rem}.limitations-box__tip a{color:#856404;text-decoration:underline}.next-step{margin-top:20px;padding-top:20px;border-top:1px solid #cbd5e0;color:#2d3748;font-size:1.05rem}.privacy-note{margin-top:20px;padding:15px;background:#eff6f6;border-radius:6px;color:#3a6969;font-size:.95rem;border-left:3px solid #96C5C5;align-items:flex-start}.privacy-note svg{flex-shrink:0;margin-top:.1rem}.progress-info{margin-top:20px;padding:15px;background:#eff6f6;border-radius:8px;color:#3a6969;font-size:.95rem}.progress-info p{margin:5px 0}footer{text-align:center;margin-top:40px;padding:25px;color:#718096;border-top:1px solid #e2e8f0}footer p{margin:8px 0}footer strong{color:#4a5568}footer a{color:#6fafaf;text-decoration:none;font-weight:500}footer a:hover{text-decoration:underline}@media(max-width:768px){.App{padding:10px}header{padding:15px 20px}header .logo-main{height:5em!important}header h1{font-size:1.8rem}header p{font-size:.85rem}main{padding:25px}h2{font-size:1.5rem}.stats-bar{flex-direction:column;gap:15px}table{font-size:.85rem}th,td{padding:10px 8px}td.description{max-width:150px}.button-group{flex-direction:column}.primary-button,.secondary-button{width:100%;margin:10px 0}}@keyframes spin{to{transform:rotate(360deg)}}.icon-spin{animation:spin .8s linear infinite}.primary-button:disabled:before{content:"";display:inline-block;width:14px;height:14px;border:2px solid white;border-top-color:transparent;border-radius:50%;margin-right:8px;animation:spin .6s linear infinite;vertical-align:middle}.transaction-list{margin:30px 0}.transaction-list__header{margin-bottom:20px}.transaction-list__header h3{font-size:1.5rem;color:#212529;margin-bottom:8px}.transaction-list__hint{font-size:.9rem;color:#6c757d;display:flex;align-items:center;gap:6px}.toast{position:fixed;top:20px;right:20px;padding:16px 24px;border-radius:8px;font-size:.95rem;font-weight:500;box-shadow:0 6px 20px #00000026;z-index:10000;animation:slideIn .3s ease-out;max-width:400px;display:inline-flex;align-items:center;gap:.5rem}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.toast--success{background-color:#28a745;color:#fff}.toast--error{background-color:#dc3545;color:#fff}@media(max-width:768px){.toast{top:10px;right:10px;left:10px;max-width:none}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{width:100%}
