:root{--font-ui: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-data: "JetBrains Mono", "SF Mono", Consolas, "Liberation Mono", Menlo, monospace;--primary: #0f172a;--primary-dark: #020617;--primary-light: #1e293b;--secondary-gray: #64748b;--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--border-color: #e2e8f0;--background: #f8fafc;--background-white: #ffffff;--success: #10b981;--success-light: #d1fae5;--error: #ef4444;--error-light: #fee2e2;--warning: #f59e0b;--info: #64748b;--info-light: #f1f5f9;font-family:var(--font-ui);line-height:1.6;font-weight:400;color-scheme:light;color:var(--text-primary);background-color:var(--background);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background-color:#fff}#root{min-height:100vh}.layout{min-height:100vh;display:flex;flex-direction:column;background:#fff}.navbar{background:var(--background-white);border-bottom:1px solid var(--border-color);padding:0 32px;box-shadow:0 1px 3px #0000000d;position:sticky;top:0;z-index:100}.nav-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;height:72px}.nav-logo{font-size:22px;font-weight:700;color:var(--primary);text-decoration:none;letter-spacing:-.3px;transition:color .2s}.nav-logo:hover{color:var(--primary-dark)}.nav-links{display:flex;align-items:center;gap:32px}.nav-links a{color:var(--text-secondary);text-decoration:none;font-size:15px;font-weight:500;transition:color .2s;padding:8px 0;position:relative;letter-spacing:.01em}.nav-links a:hover{color:var(--text-primary)}.nav-links a.active{color:var(--primary);font-weight:600}.nav-links a.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--primary);border-radius:2px 2px 0 0}.logout-button{background:#f9fafb;border:1px solid #e5e7eb;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.logout-button:hover{background:#f3f4f6;border-color:#d1d5db;color:var(--text-primary)}.main-content{flex:1;padding:32px}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e293b,#334155);padding:20px;position:relative}.auth-container:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(15,23,42,.2) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(15,23,42,.2) 0%,transparent 50%);pointer-events:none}.auth-card{background:var(--background-white);border-radius:16px;padding:48px;width:100%;max-width:440px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;position:relative;z-index:1}.auth-card h1{margin:0 0 8px;color:var(--text-primary);font-size:32px;font-weight:700;letter-spacing:-.5px}.auth-subtitle{color:var(--text-secondary);margin:0 0 32px;font-size:15px;font-weight:400}.form-group label{display:block;margin-bottom:8px;color:var(--text-primary);font-size:14px;font-weight:600;letter-spacing:.01em}.form-group input{width:100%;padding:14px 16px;border:1.5px solid var(--border-color);border-radius:8px;font-size:15px;transition:all .2s ease;box-sizing:border-box;background:var(--background-white);color:var(--text-primary)}.form-group input:hover{border-color:var(--secondary-gray)}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0f172a1a}.auth-button{width:100%;padding:14px 24px;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:8px;letter-spacing:.01em}.auth-button:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #0f172a4d}.auth-button:active:not(:disabled){transform:translateY(0)}.auth-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.auth-link{text-align:center;margin-top:32px;color:var(--text-secondary);font-size:14px}.auth-link a{color:var(--primary);text-decoration:none;font-weight:600;transition:color .2s}.auth-link a:hover{color:var(--primary-dark);text-decoration:underline}.error-message{background:var(--error-light);color:var(--error);padding:14px 16px;border-radius:8px;margin-bottom:24px;font-size:14px;border:1px solid rgba(239,68,68,.2);font-weight:500}.transactions-container{max-width:1600px;margin:0 auto;padding:0 24px}.transactions-header{margin-bottom:24px}.transactions-header h1{margin:0 0 8px;color:var(--text-primary);font-size:32px;font-weight:600;letter-spacing:-.3px}.transactions-subtitle{margin:0;color:var(--text-secondary);font-size:15px;font-weight:400}.transactions-search{margin-bottom:16px}.transactions-filters{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:24px;align-items:center}.filter-checkbox{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--text-primary);-webkit-user-select:none;user-select:none}.filter-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--primary)}.search-input{padding:10px 16px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;width:100%;max-width:400px;transition:all .2s ease;background:var(--background-white);color:var(--text-primary)}.search-input:hover{border-color:#cbd5e1}.search-input:focus{outline:none;border-color:var(--primary)}.filter-select{padding:12px 16px;border:1.5px solid var(--border-color);border-radius:8px;font-size:14px;background:var(--background-white);cursor:pointer;transition:all .2s ease;color:var(--text-primary);font-weight:500}.filter-select:hover{border-color:var(--secondary-gray)}.filter-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0f172a1a}.table-wrapper{overflow-x:auto;background:var(--background-white);border-radius:8px}.transactions-table{width:100%;border-collapse:collapse;background:var(--background-white)}.transactions-table thead{background:var(--background-white)}.transactions-table th{padding:12px 16px;text-align:left;font-weight:600;color:var(--text-primary);font-size:12px;border-bottom:1px solid #e5e7eb;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.transactions-table th.checkbox-column{width:48px;padding:12px 16px}.transactions-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .15s ease}.transactions-table th.sortable:hover{background-color:#f9fafb}.transactions-table td{padding:14px 16px;border-bottom:1px solid #f3f4f6;font-size:14px;color:var(--text-primary);white-space:nowrap}.transactions-table tbody tr{transition:background-color .1s ease}.transactions-table tbody tr:hover{background-color:#f9fafb}.transactions-table tbody tr:last-child td{border-bottom:none}.checkbox-column{width:48px;text-align:center}.checkbox-column input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--primary)}.id-cell,.date-cell{font-family:var(--font-data);font-size:13px;color:var(--text-secondary);font-variant-numeric:tabular-nums}.actions-column{width:48px;text-align:center}.actions-button{background:none;border:none;font-size:20px;color:var(--text-secondary);cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .15s ease;line-height:1;font-weight:300}.actions-button:hover{background-color:#f3f4f6;color:var(--text-primary)}.badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.badge-debit{background:#fce7f3;color:#be185d}.badge-credit{background:#d1fae5;color:#065f46}.amount-debit{color:#dc2626;font-weight:600;font-family:var(--font-data);font-size:14px;font-variant-numeric:tabular-nums}.amount-credit{color:#059669;font-weight:600;font-family:var(--font-data);font-size:14px;font-variant-numeric:tabular-nums}.loading,.empty-state{text-align:center;padding:80px 20px;color:var(--text-secondary);font-size:15px;background:var(--background-white);border-radius:12px;border:1px solid var(--border-color)}.pagination{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-top:20px;padding:12px 0}.pagination-info{font-size:14px;color:var(--text-secondary)}.pagination-buttons{display:flex;gap:8px}.pagination-btn{padding:8px 16px;font-size:14px;font-weight:500;color:var(--text-primary);background:var(--background-white);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:background-color .15s ease,border-color .15s ease}.pagination-btn:hover:not(:disabled){background-color:#f9fafb;border-color:#cbd5e1}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.category-cell{position:relative;vertical-align:middle}.category-cell-trigger{display:inline-flex;align-items:center;padding:6px 10px;border:1px solid var(--border-color);border-radius:6px;background:var(--background-white);color:var(--text-primary);font-size:13px;cursor:pointer;transition:background-color .15s ease,border-color .15s ease;text-align:left;min-height:32px;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis}.category-cell-trigger:hover:not(:disabled){background-color:#f9fafb;border-color:#cbd5e1}.category-cell-trigger:disabled{opacity:.7;cursor:wait}.category-popover{z-index:1000;background:var(--background-white);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 10px 25px #0000001a;padding:8px 0;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}.category-popover-search{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid #f3f4f6}.category-popover-search-icon{font-size:14px;opacity:.6}.category-popover-input{flex:1;border:none;outline:none;font-size:14px;color:var(--text-primary);background:transparent}.category-popover-input::placeholder{color:var(--text-secondary)}.category-popover-section{padding:6px 0}.category-popover-section-title{padding:6px 12px 8px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.category-popover-list{list-style:none;margin:0;padding:0;max-height:200px;overflow-y:auto}.category-popover-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:none;font-size:14px;color:var(--text-primary);text-align:left;cursor:pointer;transition:background-color .1s ease}.category-popover-option:hover{background-color:#f3f4f6}.category-popover-create{color:var(--primary, #0f172a);font-weight:500}.category-popover-dot{width:8px;height:8px;border-radius:50%;background:#e5e7eb;flex-shrink:0}.category-popover-empty{padding:12px;font-size:13px;color:var(--text-secondary);font-style:italic}.statement-upload-container{max-width:900px;margin:0 auto}.statement-upload-card{background:var(--background-white);border-radius:16px;padding:40px;box-shadow:0 1px 3px #0000000d;border:1px solid var(--border-color)}.statement-upload-card h2{margin:0 0 8px;color:var(--text-primary);font-size:28px;font-weight:700;letter-spacing:-.3px}.subtitle{color:var(--text-secondary);margin:0 0 32px;font-size:15px}.upload-form{margin-bottom:40px}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:10px;color:var(--text-primary);font-size:14px;font-weight:600;letter-spacing:.01em}.form-select{width:100%;padding:14px 16px;border:1.5px solid var(--border-color);border-radius:8px;font-size:14px;background:var(--background-white);cursor:pointer;transition:all .2s ease;color:var(--text-primary);font-weight:500}.form-select:hover{border-color:var(--secondary-gray)}.form-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0f172a1a}.file-input{width:100%;padding:14px 16px;border:1.5px dashed var(--border-color);border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s ease;background:var(--background);color:var(--text-primary)}.file-input:hover{border-color:var(--primary);background:#0f172a05}.file-info{margin-top:12px;font-size:14px;color:var(--text-secondary);display:flex;gap:8px;align-items:center;font-weight:500}.file-size{color:var(--text-tertiary);font-size:13px;font-family:var(--font-data);font-variant-numeric:tabular-nums}.upload-button{width:100%;padding:14px 24px;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;letter-spacing:.01em}.upload-button:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #0f172a4d}.upload-button:active:not(:disabled){transform:translateY(0)}.upload-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.upload-result{margin-top:40px;padding-top:32px;border-top:1px solid var(--border-color)}.upload-result h3{margin:0 0 20px;color:var(--text-primary);font-size:22px;font-weight:700;letter-spacing:-.3px}.result-info{background:var(--background);padding:20px;border-radius:10px;border:1px solid var(--border-color)}.result-info p{margin:10px 0;color:var(--text-primary);font-size:14px;font-weight:500}.result-info .result-value{font-family:var(--font-data);font-variant-numeric:tabular-nums}.result-info p strong{color:var(--text-secondary);font-weight:600;margin-right:8px}.transactions-section{margin-top:32px}.transactions-section h4{margin:0 0 20px;color:var(--text-primary);font-size:18px;font-weight:700;letter-spacing:-.2px}.transactions-list{display:flex;flex-direction:column;gap:12px}.transaction-item{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:var(--background);border-radius:10px;border:1px solid var(--border-color);transition:all .2s ease}.transaction-item:hover{background:var(--background-white);box-shadow:0 2px 4px #0000000d}.transaction-date{font-size:13px;color:var(--text-tertiary);font-weight:500;font-family:var(--font-data);font-variant-numeric:tabular-nums}.transaction-details{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.transaction-counterparty{font-size:15px;color:var(--text-primary);font-weight:600}.transaction-amount{font-size:17px;font-weight:700;font-family:var(--font-data);font-variant-numeric:tabular-nums;letter-spacing:-.2px}.transaction-amount.debit{color:var(--error)}.transaction-amount.credit{color:var(--success)}.status-badge{display:inline-block;padding:6px 14px;border-radius:6px;font-size:13px;font-weight:600;text-transform:capitalize;letter-spacing:.02em}.status-badge.completed{background:var(--success-light);color:var(--success)}.status-badge.failed{background:var(--error-light);color:var(--error)}.status-badge.running{background:var(--info-light);color:var(--info)}.status-badge.pending{background:#64748b1a;color:var(--secondary-gray)}.loading,.empty-state{text-align:center;padding:40px 20px;color:var(--text-secondary);font-size:15px;background:var(--background);border-radius:10px;border:1px solid var(--border-color)}*{box-sizing:border-box}body{margin:0;font-family:var(--font-ui);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:var(--font-data)}
