.language-selector{display:flex;align-items:center;gap:8px;padding:8px 12px;background:transparent;border-radius:8px;transition:background .15s ease}.language-selector:hover{background:#6b8e231a}.language-icon{color:#6b6b6b;flex-shrink:0}.language-select{border:none;background:transparent;color:#1a1a1a;font-size:.875rem;font-weight:500;cursor:pointer;outline:none;padding:0;font-family:inherit}.language-select:focus-visible{outline:2px solid var(--color-primary-600);outline-offset:2px;border-radius:4px}@media(max-width:768px){.language-selector{padding:6px 10px}.language-select{font-size:.8125rem}}.app-sidebar{width:240px;height:100vh;background:#fafaf8;border-right:1px solid #e8e8e8;display:flex;flex-direction:column;position:fixed;left:0;top:0;z-index:100}.sidebar-brand{padding:24px 20px;border-bottom:1px solid #e8e8e8}.sidebar-brand h1{margin:0;font-size:1.25rem;font-weight:700;color:#1a1a1a;letter-spacing:-.02em}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .15s ease;color:#6b6b6b;font-size:.9375rem;font-weight:500;width:100%;text-align:left;position:relative;text-decoration:none}.nav-item:hover{background:#e8ede1;color:#1a1a18}.nav-item.active{background:#f6f8f4;color:#556b2f;font-weight:600;box-shadow:0 1px 2px #6b8e2314;border-left:3px solid #6B8E23;padding-left:9px}.nav-action{margin-top:8px;border-top:1px solid #e8e8e8;padding-top:12px}.nav-action:first-of-type{margin-top:12px}.nav-item span{flex:1}.nav-badge{background:#6b8e23;color:#fff;font-size:.6875rem;font-weight:700;padding:2px 8px;border-radius:12px;min-width:20px;text-align:center}.sidebar-bottom{padding:16px 12px;border-top:1px solid #e8e8e8;display:flex;flex-direction:column;gap:8px}.cta-button{background:#6b8e23;color:#fff;border:none;padding:12px 16px;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .15s ease}.cta-button:hover{background:#556b2f;transform:translateY(-1px);box-shadow:0 2px 4px #6b8e234d}.help-link{background:transparent;border:none;padding:8px 16px;color:#6b6b6b;font-size:.875rem;cursor:pointer;text-align:left;border-radius:6px;transition:all .15s ease}.help-link:hover{background:#e8ede1;color:#1a1a18}.user-dropdown{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px;background:#fff;border:1px solid #e8e8e8;border-radius:8px;cursor:pointer;transition:all .15s ease}.user-dropdown:hover{background:#fafaf8;border-color:#d0d0d0}.user-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.user-name{font-size:.875rem;font-weight:600;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:.75rem;color:#6b6b6b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:768px){.app-sidebar{display:none}.sidebar-drawer .app-sidebar{display:flex}}.mobile-topbar{position:fixed;top:0;left:0;right:0;height:64px;background:#fff;border-bottom:1px solid #e8e8e8;display:flex;align-items:center;padding:0 16px;padding-top:env(safe-area-inset-top);padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right));min-height:calc(64px + env(safe-area-inset-top));z-index:1000;box-shadow:0 2px 4px #00000014}.mobile-topbar-title{font-size:1.25rem;font-weight:700;color:#1a1a1a;margin:0 0 0 16px}.hamburger-menu{width:48px;height:48px;background:transparent;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:50%;transition:all .15s ease;color:#1a1a1a}.hamburger-menu:hover{background:#f5f5f5}.hamburger-menu:active{transform:scale(.95)}@media(max-width:768px){.main-content{padding-top:calc(80px + env(safe-area-inset-top))!important}.sidebar-drawer .app-sidebar{display:flex}}.sidebar-drawer{position:fixed;left:0;top:0;height:100vh;width:280px;background:#fafaf8;z-index:1002;transform:translate(-100%);transition:transform .3s ease;box-shadow:2px 0 12px #00000026;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left)}.sidebar-drawer.open{transform:translate(0)}.sidebar-drawer .app-sidebar{position:relative;width:100%;border-right:none;height:100%;overflow-y:auto;padding-bottom:env(safe-area-inset-bottom)}.close-sidebar{position:absolute;top:max(16px,env(safe-area-inset-top));right:16px;z-index:10;width:40px;height:40px;background:#fff;border:1px solid #e8e8e8;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease}.close-sidebar:hover{background:#f5f5f5}.close-sidebar:active{transform:scale(.95)}.sidebar-backdrop{position:fixed;inset:0;background:#00000080;z-index:1001;animation:fadeIn .3s ease}@media(min-width:769px){.mobile-topbar,.hamburger-menu,.sidebar-drawer,.sidebar-backdrop{display:none!important}}.speed-dial{position:fixed;bottom:var(--space-6);right:var(--space-6);z-index:9998;display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-3)}@media(min-width:769px){.speed-dial{display:none}}@media(max-width:768px){.speed-dial{bottom:var(--space-4);right:var(--space-4)}}.speed-dial-backdrop{position:fixed;inset:0;background:#0006;z-index:9997;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.speed-dial-fab{width:56px;height:56px;min-width:56px;min-height:56px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary-600) 0%,var(--color-primary-700) 100%);border:none;box-shadow:0 4px 12px #2563eb66,0 8px 24px #2563eb33;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:center;justify-content:center;padding:0;-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden}.speed-dial-fab:hover{transform:scale(1.05);box-shadow:0 6px 16px #2563eb80,0 10px 28px #2563eb4d}.speed-dial-fab:active{transform:scale(.95)}.speed-dial.open .speed-dial-fab{background:linear-gradient(135deg,var(--color-error) 0%,#dc2626 100%);box-shadow:0 4px 12px #ef444466,0 8px 24px #ef444433}.speed-dial-fab-icon{color:#fff;transition:transform .3s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:center;justify-content:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.speed-dial-fab-icon.rotate{transform:translate(-50%,-50%) rotate(45deg)}.speed-dial-fab-icon svg{display:block}.speed-dial-actions{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-2)}.speed-dial-action{display:flex;align-items:center;justify-content:flex-start;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:#fff;border:none;border-radius:28px;box-shadow:var(--shadow-lg);cursor:pointer;transition:all .2s ease;animation:slideInRight .3s cubic-bezier(.34,1.56,.64,1);min-height:48px;-webkit-tap-highlight-color:transparent}.speed-dial-action:hover{transform:translate(-4px) scale(1.02);box-shadow:0 6px 16px #00000026}.speed-dial-action:active{transform:translate(-2px) scale(.98)}.speed-dial-action.active{background:var(--color-primary-50)}.speed-dial-action.active .speed-dial-icon{background:var(--color-primary-600);color:#fff}.speed-dial-action.active .speed-dial-label{color:var(--color-primary-700);font-weight:700}.speed-dial-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-50);border-radius:50%;color:var(--color-primary-600);flex-shrink:0}.speed-dial-icon svg{display:block}.speed-dial-label{font-size:.9375rem;font-weight:600;color:var(--color-gray-900);white-space:nowrap}@keyframes slideInRight{0%{opacity:0;transform:translate(20px) scale(.8)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:768px){.speed-dial-fab{width:64px;height:64px;min-width:64px;min-height:64px}.speed-dial-fab-icon svg{width:32px;height:32px}.speed-dial-action{min-height:52px;padding:var(--space-3) var(--space-4)}.speed-dial-icon{width:36px;height:36px}.speed-dial-label{font-size:1rem}}.toast-container{position:fixed;top:var(--space-6);right:var(--space-6);z-index:10000;display:flex;flex-direction:column;gap:var(--space-3);max-width:420px;pointer-events:none}.toast{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3);padding:var(--space-4) var(--space-4);background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border-left:4px solid;animation:slideIn .3s cubic-bezier(.34,1.56,.64,1);min-width:320px;pointer-events:auto;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@keyframes slideIn{0%{transform:translate(calc(100% + var(--space-6)));opacity:0}to{transform:translate(0);opacity:1}}.toast-content{display:flex;align-items:center;gap:var(--space-3);flex:1}.toast-icon{font-size:1.25rem;font-weight:700;flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%}.toast-message{font-size:.875rem;line-height:1.5;color:var(--color-gray-900);font-weight:500}.toast-close{background:none;border:none;font-size:1.125rem;color:var(--color-gray-400);cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s ease;border-radius:4px}.toast-close:hover{color:var(--color-gray-600);background:var(--color-gray-100)}.toast-success{border-left-color:var(--color-success);background:linear-gradient(135deg,#fff,#f0fdf4)}.toast-success .toast-icon{color:var(--color-success);background:var(--color-success-bg)}.toast-error{border-left-color:var(--color-error);background:linear-gradient(135deg,#fff,#fef2f2)}.toast-error .toast-icon{color:var(--color-error);background:var(--color-error-bg)}.toast-warning{border-left-color:var(--color-warning);background:linear-gradient(135deg,#fff,#fffbeb)}.toast-warning .toast-icon{color:var(--color-warning);background:#fef3c7}.toast-info{border-left-color:var(--color-primary-500);background:linear-gradient(135deg,#fff,#eff6ff)}.toast-info .toast-icon{color:var(--color-primary-600);background:var(--color-primary-100)}@media(max-width:768px){.toast-container{left:var(--space-3);right:var(--space-3);top:calc(80px + env(safe-area-inset-top));max-width:none}.toast{min-width:auto;width:100%}}.offline-indicator{position:fixed;top:16px;right:16px;z-index:9998;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.offline-indicator:hover{transform:scale(1.1)}.status-led{width:8px;height:8px;border-radius:50%;transition:all .3s ease;box-shadow:0 0 4px #0003}.offline-indicator.online .status-led{background:#22c55e;box-shadow:0 0 8px #22c55e80}.offline-indicator.offline .status-led{background:#9ca3af;box-shadow:0 0 4px #9ca3af4d;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media(max-width:768px){.offline-indicator{top:calc(72px + env(safe-area-inset-top));right:16px}}.install-prompt{position:fixed;top:16px;left:50%;transform:translate(-50%);z-index:9998;max-width:600px;width:calc(100% - 32px);animation:slideDown .3s ease-out}.install-content{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid #e8e8e8;border-radius:12px;padding:16px 20px;box-shadow:0 4px 12px #0000001a}.install-icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6b8e23,#ff8c5a);color:#fff;border-radius:12px}.install-text{flex:1;min-width:0}.install-title{font-size:15px;font-weight:700;color:#1a1a1a;margin-bottom:4px}.install-description{font-size:13px;color:#6b6b6b;line-height:1.4}.install-button{flex-shrink:0;padding:8px 20px;border:none;border-radius:8px;background:#6b8e23;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.install-button:hover{background:#556b2f;transform:translateY(-1px)}.install-button:active{transform:translateY(0)}.install-close{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:#6b6b6b;border-radius:6px;cursor:pointer;transition:all .2s ease}.install-close:hover{background:#f5f5f5;color:#1a1a1a}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(max-width:768px){.install-prompt{inset:auto 16px 96px;transform:none;width:auto;max-width:none}.install-content{flex-wrap:wrap}.install-button{order:3;flex:1 0 auto;width:100%;margin-top:8px}@keyframes slideDown{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}}.update-notification{position:fixed;bottom:24px;right:24px;max-width:400px;background:var(--background);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 4px 12px #00000026;padding:16px;z-index:9999;animation:slideInUp .3s ease-out}.update-notification-content{display:flex;gap:12px;margin-bottom:12px}.update-notification-icon{flex-shrink:0;color:var(--color-primary-600)}.update-notification-text{display:flex;flex-direction:column;gap:4px;flex:1}.update-notification-text strong{font-size:14px;font-weight:600;color:var(--text-primary)}.update-notification-text span{font-size:13px;color:var(--text-secondary)}.update-notification-actions{display:flex;gap:8px;justify-content:flex-end}.update-notification-btn{padding:8px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;border:none;cursor:pointer;transition:all .2s}.update-notification-btn-primary{background:var(--color-primary-600);color:#fff}.update-notification-btn-primary:hover{background:var(--color-primary-700)}.update-notification-btn-secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.update-notification-btn-secondary:hover{background:var(--bg-secondary)}@keyframes slideInUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:768px){.update-notification{bottom:16px;right:16px;left:16px;max-width:none}.update-notification-actions{flex-direction:column}.update-notification-btn{width:100%}}.category-items{display:flex;flex-direction:column;gap:0;padding:16px;background:#fafaf8;border-top:1px solid #e8e8e8}.assignee-filter{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #e8e8e8}.filter-label{font-size:.875rem;font-weight:600;color:#6b6b6b}.assignee-select{padding:6px 32px 6px 12px;background:#fff;border:1px solid #e8e8e8;border-radius:8px;font-size:.875rem;font-weight:500;color:#1a1a1a;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L6 6L11 1' stroke='%236b6b6b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;transition:all .15s ease}.assignee-select:hover{background-color:#fafaf8;border-color:#d0d0d0}.transaction-item{display:flex;align-items:center;padding:0;background:#fff;border-radius:0;margin-bottom:0;transition:all .15s ease;cursor:pointer}.transaction-item:last-child{margin-bottom:0}.transaction-item:hover{background:transparent;transform:none;box-shadow:none}.transaction-item.cleared{opacity:.6}.transaction-checkbox{width:32px;height:32px;min-width:32px;border:2px solid #d0d0d0;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;padding:0}.transaction-checkbox:hover{border-color:#1a1a1a;background:#f5f5f5}.transaction-checkbox.checked{background:#1a1a1a;border-color:#1a1a1a;color:#fff}.status-button{border:none!important;background:transparent!important;box-shadow:none!important;padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s ease}.status-button:hover{box-shadow:none!important;transform:scale(1.1);background:transparent!important}.status-button:active{transform:scale(1)}.merchant-logo{width:40px;min-width:40px;aspect-ratio:1;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;color:#fff;text-transform:uppercase;overflow:hidden}.transaction-info{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}.transaction-merchant{font-size:1rem;font-weight:600;color:#1a1a1a;line-height:1.3;display:flex;align-items:center;gap:6px}.split-indicator-inline{font-size:.75rem;opacity:.7}.transaction-category{display:flex;align-items:center;gap:8px;font-size:.875rem;color:#6b6b6b}.split-badge-inline{background:#f0f7ff;padding:3px 8px;border-radius:12px;color:#1e40af;font-weight:500;font-size:.75rem}.category-label{font-weight:500}.assignee-badge{padding:2px 8px;background:#f0f0f0;border-radius:12px;font-size:.75rem;font-weight:600;color:#6b6b6b}.transaction-amount{font-size:1.125rem;font-weight:700;color:#1a1a1a;white-space:nowrap;letter-spacing:-.01em}@media(max-width:768px){.transaction-item{padding:0}.transaction-checkbox{width:28px;height:28px;min-width:28px}.merchant-logo{width:36px;min-width:36px;aspect-ratio:1;border-radius:50%;font-size:.875rem;overflow:hidden}.transaction-merchant{font-size:.9375rem}.transaction-category{font-size:.8125rem}.transaction-amount{font-size:1rem}.assignee-filter{flex-direction:column;align-items:stretch}.assignee-select{width:100%}}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px}.metric-card{background:#fff;padding:20px;border-radius:12px;box-shadow:0 1px 2px #0000000a;border:1px solid var(--border, #e8e8e8);display:flex;align-items:center;gap:12px}.metric-content{display:flex;flex-direction:column}.metric-value{font-size:1.5rem;font-weight:800;margin-bottom:8px}.metric-label{font-size:.6875rem;font-weight:600;color:#6b6b6b;text-transform:uppercase;letter-spacing:.05em}.metric-card.income .metric-value{color:#1b9e77}.metric-card.expense .metric-value{color:#bc5090}.metric-card.net .metric-value{color:var(--text-primary, #1a1a1a)}.transactions-screen{width:100%;max-width:1400px;margin:0 auto;padding:0}.transactions-topbar{display:flex;align-items:center;justify-content:space-between;padding:24px 0;margin-bottom:16px}.page-title{font-size:1.75rem;font-weight:700;color:#1a1a1a;margin:0;letter-spacing:-.02em}.topbar-actions{display:flex;gap:8px;align-items:center}.action-button{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid #e8e8e8;background:#fff;color:#1a1a1a;font-size:.875rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .15s ease;position:relative}.action-button:hover{background:#f5f5f5;border-color:#d0d0d0}.action-button.active{background:#6b8e23;border-color:#6b8e23;color:#fff}.filter-badge{background:#fff;color:#6b8e23;font-size:.75rem;font-weight:700;padding:2px 6px;border-radius:10px;min-width:20px;text-align:center;line-height:1}.cta-button{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;background:#6b8e23;color:#fff;font-size:.875rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .15s ease}.cta-button:hover{background:#e55a2b}.selection-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:#fff;border-radius:12px 12px 0 0;border-bottom:1px solid #e8e8e8}.selection-left{display:none;align-items:center}.selection-bar:has(input[type=checkbox]:checked) .selection-left,.selection-bar:has(input[type=checkbox]:focus) .selection-left,.selection-bar.show-checkboxes .selection-left{display:flex}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.9375rem;font-weight:500;color:#1a1a1a}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.shortcut{font-size:.75rem;color:#999;background:#f5f5f5;padding:2px 6px;border-radius:4px;margin-left:4px}.selection-actions{display:flex;gap:12px;align-items:center}.text-button{padding:6px 12px;border:none;background:transparent;color:#6b6b6b;font-size:.875rem;font-weight:500;cursor:pointer;transition:color .15s ease}.text-button:hover{color:#1a1a1a}.edit-button{padding:6px 12px;border:none;background:#f0f0f0;color:#1a1a1a;font-size:.875rem;font-weight:600;border-radius:6px;cursor:pointer;transition:all .15s ease}.edit-button:hover{background:#e0e0e0}.sort-button{display:flex;align-items:center;gap:6px;padding:6px 12px;border:none;background:transparent;color:#1a1a1a;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.sort-button:hover{background:#f5f5f5;border-radius:6px}.sort-icon{font-size:.625rem;color:#999}.transactions-list{background:#fff;border-radius:0 0 12px 12px;overflow:hidden;width:100%}.transaction-item{display:flex;flex-direction:column;width:100%}.transaction-row{display:flex;align-items:center;gap:16px;padding:16px 20px;border-bottom:1px solid #f8f8f8;transition:background .15s ease;cursor:pointer;position:relative;width:100%;box-sizing:border-box}.transaction-row:hover{background:#fafaf8}.transaction-row.selected{background:#f0f7ff}.transaction-row:last-child{border-bottom:none}.row-checkbox{width:32px;height:32px;min-width:32px;border:2px solid #d0d0d0;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;padding:0;appearance:none;-webkit-appearance:none;-moz-appearance:none;margin:0;flex-shrink:0}.row-checkbox:hover{border-color:#1a1a1a;background:#f5f5f5}.row-checkbox:checked{background:#1a1a1a;border-color:#1a1a1a}.row-checkbox:checked:after{content:"✓";color:#fff;font-size:16px;font-weight:700}.transaction-date-compact{font-size:.6875rem;font-weight:600;color:#6b6b6b;text-transform:uppercase;letter-spacing:.3px;line-height:1;white-space:nowrap}.merchant-logo{width:36px;aspect-ratio:1;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9375rem;flex-shrink:0;line-height:1;overflow:hidden}.transaction-details{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center}.merchant-name{font-size:.875rem;font-weight:600;color:#1a1a1a;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3;display:flex;align-items:center;gap:6px}.split-indicator{font-size:.75rem;opacity:.7}.transaction-meta{display:flex;gap:8px;align-items:center;line-height:1.3;flex-wrap:wrap}.category-badge,.account-badge,.description-note{display:flex;align-items:center;gap:4px;font-size:.75rem;color:#6b6b6b;line-height:1}.split-badge{background:#f0f7ff;padding:3px 8px;border-radius:12px;color:#1e40af;font-weight:500}.description-note{font-style:italic;font-size:.75rem;max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-icon,.account-icon{flex-shrink:0;color:#6b6b6b}.transaction-amount{font-size:1rem;font-weight:700;color:#1a1a1a;letter-spacing:-.01em;flex-shrink:0;min-width:90px;text-align:right;margin-left:auto;display:flex;flex-direction:column;align-items:flex-end;gap:2px}.transaction-amount[data-positive=true]{color:#22c55e}.split-button,.expand-button{width:28px;height:28px;min-width:28px;border:none;background:transparent;color:#999;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:6px;transition:all .15s ease;flex-shrink:0;padding:0}.split-button:hover{background:#f5f5f5;color:#6b8e23}.expand-button:hover{background:#f5f5f5;color:#1a1a1a}.expand-button.expanded{transform:rotate(90deg);color:#1a1a1a;background:#f5f5f5}.transaction-details-panel{background:#fafaf8;padding:16px 20px;border-bottom:1px solid #e8e8e8;animation:slideDown .2s ease;width:100%;box-sizing:border-box;box-shadow:0 2px 4px #0000000f}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-item-full{grid-column:1 / -1}.detail-label{font-size:.75rem;font-weight:600;color:#6b6b6b;text-transform:uppercase;letter-spacing:.05em}.detail-value{font-size:.9375rem;color:#1a1a1a;font-weight:500}.splits-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.split-detail{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#fff;border-radius:6px;border:1px solid #e8e8e8}.split-category{flex:1;font-size:.875rem;font-weight:500;color:#1a1a1a}.split-amount{font-size:.9375rem;font-weight:700;color:#1a1a1a}.split-notes{font-size:.8125rem;color:#6b6b6b;font-style:italic}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;text-align:center}.empty-state p{font-size:1rem;color:#6b6b6b;margin:0 0 24px}@media(max-width:1024px){.topbar-actions{flex-wrap:wrap}.action-button span{display:none}.cta-button span{display:inline}}@media(max-width:768px){.transactions-topbar{display:none}.page-title{font-size:1.5rem}.topbar-actions{display:none}.action-button{padding:8px 12px}.selection-bar{padding:12px 16px}.transaction-row{gap:8px;padding:12px}.row-checkbox{width:24px;height:24px;min-width:24px;min-height:24px;aspect-ratio:1;flex-shrink:0}.row-checkbox:checked:after{font-size:12px}.transaction-date-compact{font-size:.625rem}.merchant-logo{width:32px;aspect-ratio:1;border-radius:50%;font-size:.8125rem;overflow:hidden}.merchant-name{font-size:.8125rem}.transaction-meta{flex-direction:column;gap:2px;align-items:flex-start}.category-badge,.account-badge,.description-note{font-size:.6875rem}.transaction-amount{font-size:.875rem;min-width:auto;margin-left:auto}.split-button,.expand-button{width:24px;height:24px;min-width:24px}.split-button svg,.expand-button svg{width:14px;height:14px}.transaction-details-panel{padding:12px}.detail-grid{grid-template-columns:1fr;gap:8px}}.filters-bar{display:flex;flex-direction:column;gap:12px;padding:16px 20px;background:#fafaf8;border-bottom:1px solid #e8e8e8}.filters-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.filter-dropdown-wrapper{position:relative}.filter-button{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#fff;border:1px solid #d0d0d0;border-radius:6px;font-size:.875rem;font-weight:500;color:#1a1a1a;cursor:pointer;transition:all .15s ease;white-space:nowrap}.filter-button:hover{background:#f5f5f5;border-color:#1a1a1a}.filter-button.active{background:#1a1a1a;border-color:#1a1a1a;color:#fff}.filter-button-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;background:#fff3;border-radius:9px;font-size:.75rem;font-weight:700;line-height:1}.filter-button.active .filter-button-count{background:#ffffff40;color:#fff}.filter-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:220px;max-height:320px;overflow-y:auto;background:#fff;border:1px solid #e8e8e8;border-radius:8px;box-shadow:0 4px 16px #0000001f;z-index:1000;padding:6px;text-align:left}.filter-dropdown::-webkit-scrollbar{width:8px}.filter-dropdown::-webkit-scrollbar-track{background:transparent;margin:4px}.filter-dropdown::-webkit-scrollbar-thumb{background:#d0d0d0;border-radius:4px}.filter-dropdown::-webkit-scrollbar-thumb:hover{background:#b0b0b0}.filter-dropdown-item{display:flex;align-items:center;justify-content:flex-start;padding:10px 12px;border-radius:6px;cursor:pointer;transition:background .12s ease;-webkit-user-select:none;user-select:none;min-height:36px;position:relative;text-align:left}.filter-dropdown-item:hover{background:#f5f5f5}.filter-dropdown-item:active{background:#ebebeb}.filter-dropdown-item input[type=checkbox],.filter-dropdown-item input[type=radio]{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.filter-dropdown-item input[type=radio]:checked{border-color:#1a1a1a;background:#fff}.filter-dropdown-item input[type=radio]:checked:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:10px;height:10px;background:#1a1a1a;border-radius:50%}.filter-dropdown-label{display:flex;align-items:center;justify-content:flex-start;gap:8px;font-size:.875rem;font-weight:500;color:#1a1a1a;flex:1;line-height:1.4;cursor:pointer;padding-left:28px;position:relative;text-align:left;width:100%}.filter-dropdown-label>*{text-align:left}.filter-dropdown-item input[type=checkbox]+.filter-dropdown-label:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:18px;height:18px;border:2px solid #d0d0d0;border-radius:4px;background:#fff;transition:all .15s ease}.filter-dropdown-item:hover input[type=checkbox]+.filter-dropdown-label:before{border-color:#1a1a1a}.filter-dropdown-item input[type=checkbox]:checked+.filter-dropdown-label:before{background:#1a1a1a;border-color:#1a1a1a}.filter-dropdown-item input[type=checkbox]:checked+.filter-dropdown-label:after{content:"✓";position:absolute;left:3px;top:50%;transform:translateY(-50%);color:#fff;font-size:12px;font-weight:700;line-height:1}.filter-dropdown-item input[type=radio]+.filter-dropdown-label:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:18px;height:18px;border:2px solid #d0d0d0;border-radius:50%;background:#fff;transition:all .15s ease}.filter-dropdown-item:hover input[type=radio]+.filter-dropdown-label:before{border-color:#1a1a1a}.filter-dropdown-item input[type=radio]:checked+.filter-dropdown-label:before{border-color:#1a1a1a}.filter-dropdown-item input[type=radio]:checked+.filter-dropdown-label:after{content:"";position:absolute;left:5px;top:50%;transform:translateY(-50%);width:10px;height:10px;background:#1a1a1a;border-radius:50%}.filter-emoji{font-size:1rem;line-height:1}.clear-filters-button{padding:6px 12px;background:transparent;border:none;border-radius:6px;font-size:.875rem;font-weight:500;color:#6b6b6b;cursor:pointer;transition:all .15s ease}.clear-filters-button:hover{background:#f5f5f5;color:#1a1a1a}.apply-filters-button{padding:6px 16px;background:#1a1a1a;border:none;border-radius:6px;font-size:.875rem;font-weight:600;color:#fff;cursor:pointer;transition:all .15s ease}.apply-filters-button:hover{background:#333}.active-filters{display:flex;flex-wrap:wrap;gap:6px;padding-top:4px}.filter-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px 4px 10px;background:#1a1a1a;color:#fff;border-radius:16px;font-size:.8125rem;font-weight:500;line-height:1.4}.filter-chip-emoji{font-size:.875rem;line-height:1}.filter-chip-remove{display:flex;align-items:center;justify-content:center;width:16px;height:16px;padding:0;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;transition:background .15s ease}.filter-chip-remove:hover{background:#ffffff4d}.sort-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px 4px 10px;background:#1a1a1a;color:#fff;border-radius:16px;font-size:.8125rem;font-weight:500;line-height:1.4}@media(max-width:768px){.filters-bar{padding:12px 16px}.filters-controls{gap:6px}.filter-button{font-size:.8125rem;padding:6px 10px}.filter-dropdown{min-width:200px;max-height:280px;left:0;right:auto}.filter-dropdown-item{padding:9px 10px;min-height:34px}.filter-dropdown-label{font-size:.8125rem;padding-left:26px}.filter-dropdown-item input[type=checkbox]+.filter-dropdown-label:before,.filter-dropdown-item input[type=radio]+.filter-dropdown-label:before{width:16px;height:16px}.filter-dropdown-item input[type=checkbox]:checked+.filter-dropdown-label:after{left:2px;font-size:11px}.filter-dropdown-item input[type=radio]:checked+.filter-dropdown-label:after{left:4px;width:8px;height:8px}}.screen-container{width:100%;max-width:1400px;margin:0 auto;padding:0}.screen-header{margin-bottom:32px}.screen-title{font-size:2rem;font-weight:700;color:#1a1a1a;margin:0 0 8px;letter-spacing:-.02em}.screen-subtitle{font-size:1rem;color:#6b6b6b;margin:0}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-bottom:32px}.metric-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 2px #0000000a;display:flex;align-items:center;gap:16px}.metric-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff}.metric-card.income .metric-icon{background:linear-gradient(135deg,#22c55e,#16a34a)}.metric-card.expense .metric-icon{background:linear-gradient(135deg,#ef4444,#dc2626)}.metric-card.net .metric-icon{background:linear-gradient(135deg,#3b82f6,#2563eb)}.metric-content{flex:1;display:flex;flex-direction:column;gap:4px}.metric-label{font-size:.875rem;font-weight:600;color:#6b6b6b;text-transform:uppercase;letter-spacing:.05em}.metric-value{font-size:1.75rem;font-weight:800;letter-spacing:-.02em}.metric-value.positive{color:#22c55e}.metric-value.negative{color:#ef4444}.content-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 2px #0000000a}.placeholder-content{background:#fff;border-radius:12px;padding:64px 24px;box-shadow:0 1px 2px #0000000a;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:16px;color:#6b6b6b}.placeholder-content svg{opacity:.3}.placeholder-content h3{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin:0}.placeholder-content p{font-size:.9375rem;margin:0;max-width:500px}@media(max-width:768px){.screen-container{padding:0}.screen-header{margin-bottom:24px}.screen-title{font-size:1.5rem}.screen-subtitle{font-size:.875rem}.metrics-grid{grid-template-columns:1fr;gap:16px}.metric-card{padding:20px}.metric-value{font-size:1.5rem}.placeholder-content{padding:48px 16px}}.reports-type-toggle{display:flex;gap:8px;margin-bottom:16px}.toggle-btn{flex:1;padding:10px 16px;background:#f5f5f5;border:1px solid #e8e8e8;border-radius:8px;font-size:.875rem;font-weight:600;color:#6b6b6b;cursor:pointer;transition:all .2s}.toggle-btn:hover{background:#efefef}.toggle-btn.active{background:#6b8e23;color:#fff;border-color:#6b8e23}.reports-datemode-toggle{display:flex;gap:8px;margin-bottom:16px}.mode-btn{flex:1;padding:10px 16px;background:#f5f5f5;border:1px solid #e8e8e8;border-radius:8px;font-size:.875rem;font-weight:600;color:#6b6b6b;cursor:pointer;transition:all .2s}.mode-btn:hover{background:#efefef}.mode-btn.active{background:#6b8e23;color:#fff;border-color:#6b8e23}.reports-month-selector{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:24px;padding:12px;background:#fff;border:1px solid #e8e8e8;border-radius:12px}.nav-btn{padding:8px;background:transparent;border:none;cursor:pointer;color:#6b6b6b;transition:all .2s}.nav-btn:hover{color:#1a1a1a;transform:scale(1.1)}.current-month{font-size:1rem;font-weight:600;color:#1a1a1a;min-width:150px;text-align:center}.reports-range-selector{display:flex;gap:16px;margin-bottom:24px;padding:12px;background:#fff;border:1px solid #e8e8e8;border-radius:12px}.range-input{display:flex;align-items:center;gap:8px;flex:1}.range-input label{font-size:.875rem;font-weight:600;color:#6b6b6b;white-space:nowrap}.month-input{flex:1;padding:8px 12px;border:1px solid #e8e8e8;border-radius:8px;font-size:.875rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.month-input:focus{outline:none;border-color:#6b8e23;box-shadow:0 0 0 3px #6b8e231a}.reports-chart-container{margin-bottom:24px;background:#fff;padding:20px;border:1px solid #e8e8e8;border-radius:12px}.stacked-bar-chart{display:flex;flex-direction:column;gap:20px}.chart-bar{display:flex;height:40px;background:#f5f5f5;border-radius:8px;overflow:hidden;box-shadow:0 1px 2px #0000000a}.chart-segment{flex:0 0 auto;transition:all .2s;cursor:pointer}.chart-segment:hover{opacity:.8;filter:brightness(.95)}.chart-legend{display:flex;flex-direction:column;gap:12px}.legend-item{display:flex;align-items:center;gap:12px;padding:8px;border-radius:8px;transition:all .2s}.legend-item:hover{background:#f9fafb}.legend-color{width:16px;height:16px;border-radius:4px;flex-shrink:0}.legend-info{flex:1;display:flex;justify-content:space-between;align-items:center;gap:12px}.legend-name{font-size:.875rem;font-weight:600;color:#1a1a1a}.legend-value{font-size:.875rem;color:#6b6b6b}.reports-total{text-align:center;margin-bottom:24px;padding:20px;background:#f9fafb;border:1px solid #e8e8e8;border-radius:12px}.total-label{font-size:.6875rem;font-weight:600;color:#6b6b6b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.total-amount{font-size:2.25rem;font-weight:800;color:#1a1a1a}.reports-transactions{margin-top:24px}.list-header{font-size:1rem;font-weight:600;color:#1a1a1a;margin-bottom:16px}.transaction-list{display:flex;flex-direction:column;gap:12px}.transaction-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#fff;border:1px solid #e8e8e8;border-radius:8px;cursor:pointer;transition:all .2s}.transaction-item:hover{background:#fafaf8;border-color:#d0d0d0}.tx-left{flex:1;display:flex;flex-direction:column;gap:4px}.tx-header{display:flex;align-items:center;gap:8px}.tx-desc{font-size:.875rem;font-weight:600;color:#1a1a1a}.tx-footer{display:flex;align-items:center;gap:8px}.tx-meta{display:flex;align-items:center;gap:8px;font-size:.75rem;color:#9ca3af}.tx-category,.tx-account,.tx-date{padding:2px 6px;background:#f5f5f5;border-radius:4px}.tx-right{font-size:.875rem;font-weight:600;color:#1a1a1a}.reports-empty{text-align:center;padding:40px 20px;color:#9ca3af}@media(max-width:768px){.reports-range-selector{flex-direction:column}.legend-info{flex-direction:column;align-items:flex-start}.transaction-item{flex-direction:column;align-items:flex-start;gap:8px}.tx-right{align-self:flex-end}}.legend-item{display:flex;align-items:center;gap:8px;font-size:.875rem;color:#6b6b6b}.legend-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}@media(max-width:768px){.reports-controls{flex-direction:column;align-items:stretch}.period-selector{width:100%;justify-content:center}.reports-chart-container{margin-left:-16px;margin-right:-16px;padding:0 16px}.reports-legend{flex-direction:column;align-items:flex-start;gap:12px}}.budget-screen{width:100%;max-width:1400px;margin:0 auto;padding:0}.budget-topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 0;margin-bottom:24px;border-bottom:1px solid #e8e8e8}.budget-nav{display:flex;align-items:center;gap:12px}.month-nav-btn{width:32px;height:32px;border:none;background:#fff;border-radius:8px;color:#1a1a1a;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.month-nav-btn:hover{background:#f5f5f5}.month-title{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin:0}.budget-tabs{display:flex;gap:8px;background:#f5f5f5;padding:4px;border-radius:8px}.tab-btn{padding:8px 20px;border:none;background:transparent;color:#6b6b6b;font-size:.875rem;font-weight:600;cursor:pointer;border-radius:6px;transition:all .15s ease}.tab-btn.active{background:#fff;color:#1a1a1a;box-shadow:0 1px 2px #0000000f}.budget-actions{display:flex;gap:8px}.action-btn{padding:8px 16px;border:1px solid #e8e8e8;background:#fff;color:#1a1a1a;font-size:.875rem;font-weight:500;cursor:pointer;border-radius:8px;display:flex;align-items:center;gap:6px;transition:all .15s ease}.action-btn:hover{background:#f5f5f5}.budget-content{display:grid;grid-template-columns:1fr 320px;gap:24px}.budget-table-container{background:#fff;border-radius:12px;padding:0;box-shadow:0 1px 2px #0000000a}.budget-table{width:100%}.budget-group{border-bottom:1px solid #f0f0f0}.budget-group:last-child{border-bottom:none}.group-header{width:100%;display:flex;align-items:center;gap:12px;padding:16px 20px;border:none;background:#fafaf8;cursor:pointer;transition:background .15s ease}.group-header:hover{background:#f5f5f5}.group-name{font-size:.875rem;font-weight:600;color:#6b6b6b;text-transform:uppercase;letter-spacing:.05em;flex:1}.group-totals{display:flex;gap:100px;align-items:center}.total-budget,.total-actual,.total-remaining{font-size:1rem;font-weight:700;color:#1a1a1a;min-width:100px;text-align:right}.total-remaining.positive{color:#22c55e}.total-remaining.negative{color:#ef4444}.expenses-header{display:flex;align-items:center;gap:12px;padding:16px 20px;background:#f5f5f5;border-bottom:1px solid #e8e8e8;font-size:.875rem;font-weight:600;color:#6b6b6b;text-transform:uppercase;letter-spacing:.05em}.header-labels{display:flex;gap:100px;margin-left:auto;font-size:.75rem;color:#999}.header-labels span{min-width:100px;text-align:right}.group-categories{padding:0}.budget-row{display:flex;align-items:center;padding:12px 20px;border-bottom:1px solid #f8f8f8;transition:background .15s ease}.budget-row:hover{background:#fafaf8}.budget-row:last-child{border-bottom:none}.category-info{display:flex;align-items:center;gap:12px;flex:1;padding-left:28px}.category-icon{flex-shrink:0;color:#6b6b6b}.category-name{font-size:.9375rem;color:#1a1a1a;font-weight:500}.budget-values{display:flex;gap:100px;align-items:center}.value-budget,.value-actual,.value-remaining{font-size:.9375rem;font-weight:600;color:#1a1a1a;min-width:100px;text-align:right}.progress-bar{position:absolute;bottom:0;left:0;right:0;height:3px;background:#f0f0f0;overflow:hidden}.budget-row{position:relative}.progress-fill{height:100%;transition:width .3s ease}.progress-fill.ok{background:linear-gradient(90deg,#22c55e,#16a34a)}.progress-fill.over{background:linear-gradient(90deg,#ef4444,#dc2626)}.group-total-row{display:flex;align-items:center;padding:12px 20px;background:#fafaf8;border-top:1px solid #e8e8e8}.total-label{flex:1;font-size:.875rem;font-weight:600;color:#1a1a1a;padding-left:28px}.total-values{display:flex;gap:100px;align-items:center}.total-values span{font-size:1rem;font-weight:700;color:#1a1a1a;min-width:100px;text-align:right}.total-values .positive{color:#22c55e}.budget-summary-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 2px #0000000a;height:fit-content;position:sticky;top:24px}.summary-header{text-align:center;margin-bottom:24px}.left-to-budget{font-size:2.5rem;font-weight:800;color:#22c55e;margin:0;letter-spacing:-.02em}.summary-label{display:block;font-size:.6875rem;font-weight:600;color:#6b6b6b;text-transform:uppercase;letter-spacing:.05em;margin-top:4px}.summary-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:1px solid #e8e8e8}.summary-tab{flex:1;padding:8px 12px;border:none;background:transparent;color:#6b6b6b;font-size:.8125rem;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s ease}.summary-tab:hover{color:#1a1a1a}.summary-tab.active{color:#1a1a1a;border-bottom-color:#1a1a1a}.summary-sections{display:flex;flex-direction:column;gap:20px}.summary-section{padding:16px;background:#fafaf8;border-radius:8px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.section-label{font-size:.875rem;font-weight:600;color:#1a1a1a}.section-budget{font-size:.75rem;color:#6b6b6b}.section-bar{height:8px;background:#e8e8e8;border-radius:4px;overflow:hidden;margin-bottom:8px;display:flex}.bar-fill{height:100%;transition:width .3s ease}.bar-fill.ok{background:linear-gradient(90deg,#22c55e,#16a34a)}.bar-fill.warning{background:linear-gradient(90deg,#eab308,#ca8a04)}.bar-fill.over{background:linear-gradient(90deg,#ef4444,#dc2626)}.section-values{display:flex;justify-content:space-between;font-size:.875rem}.value-spent{color:#1a1a1a;font-weight:600}.value-remaining{font-weight:700}.value-remaining.positive{color:#22c55e}.value-remaining.negative{color:#ef4444}@media(max-width:1024px){.budget-content{grid-template-columns:1fr}.budget-summary-card{position:relative;top:0}.budget-topbar{flex-direction:column;gap:12px;align-items:stretch}.budget-nav,.budget-actions{justify-content:center}.group-totals,.budget-values,.total-values,.header-labels{gap:40px}.total-budget,.total-actual,.total-remaining,.value-budget,.value-actual,.value-remaining{min-width:80px;font-size:.875rem}}@media(max-width:768px){.budget-screen{padding:0}.budget-topbar{padding:12px 16px}.budget-tabs{width:100%}.action-btn span{display:none}.month-title{font-size:1rem}.category-info{padding-left:12px}.category-name{font-size:.875rem}.group-totals,.budget-values,.total-values{gap:20px}.header-labels{gap:20px;font-size:.625rem}.total-budget,.total-actual,.total-remaining,.value-budget,.value-actual,.value-remaining{min-width:60px;font-size:.8125rem}.left-to-budget{font-size:2rem}}.budget-empty{padding:48px 24px;text-align:center;color:#6b6b6b}.budget-empty p{margin:8px 0;font-size:.9375rem}.empty-group{padding:24px 48px;color:#999;font-size:.875rem;font-style:italic}.left-to-budget.positive{color:#22c55e}.left-to-budget.negative{color:#ef4444}.bar-fill.income{background:linear-gradient(90deg,#3b82f6,#2563eb)}.section-budget.positive{color:#22c55e}.section-budget.negative{color:#ef4444}.value-budget .editable-cell{cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .15s ease}.value-budget .editable-cell:hover{background:#f0f0f0}.value-budget input{width:80px;padding:4px 8px;border:1px solid #e8e8e8;border-radius:4px;font-size:.9375rem;font-weight:600;text-align:right;outline:none}.value-budget input:focus{border-color:#6b8e23;box-shadow:0 0 0 2px #6b8e231a}.modal-backdrop{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:modal-fade-in .2s ease}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border-radius:12px;width:100%;min-width:320px;max-width:480px;max-height:calc(100vh - 40px);overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 40px #00000026;animation:modal-slide-up .3s ease}.modal--wide{max-width:560px}.modal--large{max-width:680px}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e8e8e8;flex-shrink:0}.modal-header h2,.modal-header h3,.modal-title{margin:0;font-size:1.125rem;font-weight:700;color:#1a1a1a;line-height:1.3}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;background:transparent;border-radius:8px;color:#6b6b6b;cursor:pointer;transition:all .15s ease;flex-shrink:0;margin-left:12px}.modal-close:hover{background:#f5f5f5;color:#1a1a1a}.modal-body{padding:24px;flex:1;overflow-y:auto;width:100%;box-sizing:border-box}.modal-footer,.modal-actions{display:flex;gap:12px;padding:16px 24px;border-top:1px solid #e8e8e8;flex-shrink:0;background:#fafaf8;width:100%;box-sizing:border-box;justify-content:flex-end}.modal-footer--stacked{flex-direction:column}.modal form,.modal-form,.form{display:flex;flex-direction:column;width:100%}.modal-body .form-group+.form-group{margin-top:20px}.form-label{font-size:.875rem;font-weight:600;color:#1a1a1a;line-height:1.3}.form-input,.form-select,.form-group input,.form-group select,.form-group textarea{width:100%;max-width:100%;padding:12px 14px;font-size:.9375rem;font-weight:400;border:1px solid #e8e8e8;border-radius:8px;background:#fff;color:#1a1a1a;transition:all .15s ease;box-sizing:border-box}.form-group input[type=date],.form-group input[type=month],input[type=date],input[type=month]{width:100%!important;max-width:100%!important;min-width:0;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-input:focus,.form-select:focus,.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#6b8e23;box-shadow:0 0 0 3px #6b8e231a}.form-input:disabled,.form-select:disabled,.form-group input:disabled,.form-group select:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.form-input::placeholder,.form-group input::placeholder{color:#999}.form-hint{font-size:.8125rem;font-weight:400;color:#6b6b6b;font-style:normal;margin-top:2px}.kind-toggle{display:grid;grid-template-columns:1fr 1fr;gap:8px}.kind-toggle button{padding:12px;border:2px solid #e8e8e8;border-radius:8px;background:#fff;color:#6b6b6b;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .15s ease}.kind-toggle button:hover{border-color:#d0d0d0;background:#fafaf8}.kind-toggle button.active.expense{border-color:#ef4444;background:#ef4444;color:#fff}.kind-toggle button.active.income{border-color:#22c55e;background:#22c55e;color:#fff}.modal form button[type=submit],.modal-form button[type=submit],.btn-submit{margin-top:4px;padding:14px 24px;font-size:.9375rem;font-weight:600;background:#1a1a1a;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .15s ease}.modal form button[type=submit]:hover:not(:disabled),.modal-form button[type=submit]:hover:not(:disabled),.btn-submit:hover:not(:disabled){background:#2d2d2d}.modal form button[type=submit]:disabled,.modal-form button[type=submit]:disabled,.btn-submit:disabled{opacity:.5;cursor:not-allowed}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;font-size:.9375rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .15s ease;border:1px solid transparent}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary,.primary-button{background:#1a1a1a;color:#fff;border-color:#1a1a1a}.btn-primary:hover:not(:disabled),.primary-button:hover:not(:disabled){background:#2d2d2d;border-color:#2d2d2d}.btn-secondary,.secondary-button{background:#fff;color:#1a1a1a;border-color:#e8e8e8}.btn-secondary:hover:not(:disabled),.secondary-button:hover:not(:disabled){background:#f5f5f5;border-color:#d0d0d0}.btn-accent{background:#6b8e23;color:#fff;border-color:#6b8e23}.btn-accent:hover:not(:disabled){background:#556b2f;border-color:#556b2f}.btn-danger,.danger-button{background:#ef4444;color:#fff;border-color:#ef4444}.btn-danger:hover:not(:disabled),.danger-button:hover:not(:disabled){background:#dc2626;border-color:#dc2626}.btn-outline-danger{background:transparent;color:#ef4444;border-color:#ef4444}.btn-outline-danger:hover:not(:disabled){background:#fef2f2}.btn-ghost{background:transparent;color:#6b6b6b;border-color:transparent;padding:8px 12px}.btn-ghost:hover:not(:disabled){background:#f5f5f5;color:#1a1a1a}.btn-dashed{background:transparent;color:#6b6b6b;border:2px dashed #e8e8e8}.btn-dashed:hover:not(:disabled){border-color:#6b8e23;color:#6b8e23;background:#fff9f5}.btn-block{width:100%}.btn-sm{padding:8px 14px;font-size:.8125rem}.btn-icon{padding:8px;width:36px;height:36px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group+.form-group{margin-top:16px}.form-label{font-size:.875rem;font-weight:600;color:#1a1a1a}.form-input,.form-select,.modal form input,.modal form select,.modal form textarea{width:100%;padding:10px 12px;font-size:.9375rem;border:1px solid #e8e8e8;border-radius:8px;background:#fff;color:#1a1a1a;transition:all .15s ease}.form-input:focus,.form-select:focus,.modal form input:focus,.modal form select:focus,.modal form textarea:focus{outline:none;border-color:#6b8e23;box-shadow:0 0 0 3px #6b8e231a}.form-input:disabled,.form-select:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.form-hint{font-size:.8125rem;color:#6b6b6b}.alert{display:flex;gap:12px;padding:16px;border-radius:8px}.alert-icon{flex-shrink:0}.alert-content{flex:1;font-size:.875rem;line-height:1.5}.alert-content strong{font-weight:600}.alert-warning,.warning-box{background:#fff9f0;border:1px solid #ffe4c4;color:#1a1a1a}.alert-warning .alert-icon,.warning-box svg{color:#f59e0b}.alert-error,.error-box{background:#fef2f2;border:1px solid #fecaca;color:#1a1a1a}.alert-error .alert-icon{color:#ef4444}.alert-info,.info-box{background:#f0f9ff;border:1px solid #bae6fd;color:#1a1a1a}.alert-info .alert-icon{color:#0ea5e9}.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#1a1a1a}.alert-success .alert-icon{color:#22c55e}.modal-sections{display:flex;flex-direction:column;gap:24px}.modal-section{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding:24px;border-radius:8px;background:#fafaf8}.section-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:50%;background:#1a1a1a;color:#fff}.section-title{font-size:1.125rem;font-weight:700;color:#1a1a1a;margin:0}.section-description{font-size:.875rem;color:#6b6b6b;line-height:1.5;margin:0;max-width:400px}.section-divider{height:1px;background:#e8e8e8;margin:8px 0}.summary-card{background:#f8f9fa;padding:16px;border-radius:8px}.item-list{display:flex;flex-direction:column;gap:16px;max-height:400px;overflow-y:auto;padding:4px}.item-card{background:#fff;border:1px solid #e8e8e8;border-radius:8px;padding:16px}.item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.item-number{font-size:.875rem;font-weight:700;color:#1a1a1a;text-transform:uppercase;letter-spacing:.05em}.item-remove{background:transparent;border:none;color:#ef4444;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background .15s ease}.item-remove:hover{background:#fef2f2}.item-fields{display:flex;flex-direction:column;gap:12px}@media(max-width:768px){.modal-backdrop{padding:0;margin:0;align-items:flex-end;background:#0006}.modal{min-width:0;max-width:100%;width:100%;margin:0;padding:0;max-height:calc(100vh - 80px - env(safe-area-inset-top));min-height:60vh;border-radius:16px 16px 0 0;box-shadow:0 -4px 24px #0003;animation:modal-slide-up-mobile .3s cubic-bezier(.34,1.56,.64,1)}@keyframes modal-slide-up-mobile{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:20px;position:relative}.modal-header:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:36px;height:4px;background:#d1d5db;border-radius:2px}.modal-header h2,.modal-header h3,.modal-title{font-size:1rem;margin-top:8px}.modal-body{padding:20px}.modal form,.modal-form{gap:16px}.modal form input,.modal form select,.modal-form input,.modal-form select,.form-input,.form-select{padding:10px 12px;font-size:1rem}.modal-footer,.modal-actions{padding:16px 20px;flex-direction:column-reverse;gap:8px}.modal-actions .btn,.modal-actions button,.modal-footer .btn,.modal-footer button{width:100%}.modal form button[type=submit],.modal-form button[type=submit]{padding:14px 20px}.section-icon{width:56px;height:56px}.item-list{max-height:300px}}:root{--color-primary-50: #f6f8f4;--color-primary-100: #e8ede1;--color-primary-200: #d1dbc3;--color-primary-400: #9fb88a;--color-primary-500: #7BA05B;--color-primary-600: #6B8E23;--color-primary-700: #556B2F;--color-primary-800: #3A5F0B;--color-gray-50: #fafaf8;--color-gray-100: #f4f4f1;--color-gray-200: #e8e8e4;--color-gray-300: #d1d1cc;--color-gray-400: #9e9e96;--color-gray-500: #6b6b64;--color-gray-600: #52524c;--color-gray-700: #3a3a35;--color-gray-800: #252522;--color-gray-900: #1a1a18;--color-success: #4A7C59;--color-success-bg: #e8f5e9;--color-error: #8B4513;--color-error-bg: #ffeee8;--color-warning: #C19A6B;--color-warning-bg: #fff8e8;--color-accent-cyan: #5A8B73;--color-accent-cyan-bg: #e8f5f0;--color-accent-amber: #9ACD32;--color-accent-amber-bg: #f4f8e8;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-6: 24px;--space-8: 32px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--bp-mobile: 480px;--bp-tablet: 768px;--bp-desktop: 1024px}*,*:before,*:after{box-sizing:border-box}html,body{height:100%;min-height:100vh}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:#fafaf8;background-attachment:fixed;color:#1a1a18;line-height:1.5;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media(max-width:768px)and (-webkit-min-device-pixel-ratio:2){body{font-size:18px}}@media(max-width:768px){body{font-size:17px}}button,input,select{font:inherit}*:focus-visible{outline:3px solid var(--color-primary-600);outline-offset:2px;border-radius:var(--radius-sm)}*:focus:not(:focus-visible){outline:none}button:focus-visible,a:focus-visible,[role=button]:focus-visible{outline:3px solid var(--color-primary-600);outline-offset:2px}.form-control:focus-within{outline:2px solid var(--color-primary-600);outline-offset:1px}.layout{display:flex;min-height:100vh;background:#fafaf8}.main-content{flex:1;padding:32px;overflow-y:auto;max-width:1600px;margin:0 auto;width:100%}@media(max-width:768px){.main-content{padding:16px 0}}.content{display:flex;flex-direction:column;min-width:0;flex:1;overflow-y:auto}.mobile-topbar{display:none;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);padding-top:max(var(--space-3),env(safe-area-inset-top));padding-left:max(var(--space-4),env(safe-area-inset-left));padding-right:max(var(--space-4),env(safe-area-inset-right));background:var(--color-gray-50);border-bottom:1px solid var(--color-gray-200);box-shadow:var(--shadow-sm);min-height:calc(56px + env(safe-area-inset-top))}@media(max-width:768px){.mobile-topbar{display:flex}.content{height:100%;padding-top:0}}@media(min-width:769px){.content{padding-top:0}}.menu-button{appearance:none;background:transparent;border:none;color:var(--color-gray-700);font-size:1.5rem;padding:var(--space-2);cursor:pointer;line-height:1;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .15s ease}.menu-button:hover{background:var(--color-gray-100)}.menu-button:active{background:var(--color-gray-200)}.mobile-title{font-size:1rem;font-weight:600;color:var(--color-gray-900);flex:1}.topbar{background:linear-gradient(135deg,#fff,#f8fafc);border-bottom:1px solid var(--color-gray-200);padding:var(--space-4) 0;box-shadow:var(--shadow-sm)}@media(max-width:768px){.topbar{display:none}}.topbar-content{display:flex;align-items:center;justify-content:space-between;gap:var(--space-6);max-width:1400px;margin:0 auto;padding:0 var(--space-6)}.topbar-branding{display:flex;flex-direction:column;gap:var(--space-1)}.topbar-muted{color:var(--color-gray-500);font-size:.8125rem;line-height:1.3}.quick-actions{display:flex;gap:var(--space-2);align-items:center}.quick-action-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);background:linear-gradient(135deg,#fff,#f9fafb);color:var(--color-gray-700);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-xs)}.quick-action-btn:hover{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border-color:var(--color-gray-400);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.quick-action-btn:active{transform:translateY(0);box-shadow:var(--shadow-xs)}.quick-action-btn.primary{background:linear-gradient(135deg,var(--color-primary-600) 0%,var(--color-primary-700) 100%);color:#fff;border-color:var(--color-primary-700)}.quick-action-btn.primary:hover{background:linear-gradient(135deg,var(--color-primary-700) 0%,var(--color-primary-800) 100%);border-color:var(--color-primary-800)}.quick-action-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.quick-action-icon svg{display:block}.quick-action-label{white-space:nowrap}@media(max-width:1200px){.quick-action-label{display:none}.quick-action-btn{padding:var(--space-2);min-width:36px;justify-content:center}}main{padding:var(--space-6);overflow-y:auto;flex:1;width:100%;max-width:1400px;margin:0 auto}@media(max-width:1024px){main{padding:var(--space-4)}}@media(max-width:768px){main{padding:var(--space-3);padding-bottom:calc(var(--space-3) + env(safe-area-inset-bottom))}}@media(max-width:480px){main{padding:var(--space-2);padding-bottom:calc(var(--space-2) + env(safe-area-inset-bottom))}}h1{margin:0;font-size:1.5rem;font-weight:700;color:var(--color-gray-900);letter-spacing:-.025em}h2{margin:var(--space-6) 0 var(--space-3);font-size:1rem;font-weight:600;color:var(--color-gray-700);letter-spacing:-.015em}h3{margin:var(--space-4) 0 var(--space-2);font-size:.875rem;font-weight:600;color:var(--color-gray-600)}button{appearance:none;background:var(--color-primary-600);color:#fff;border:none;border-radius:var(--radius-sm);padding:.625rem 1rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;box-shadow:var(--shadow-sm)}button:hover:not(:disabled){background:var(--color-primary-700);transform:translateY(-1px);box-shadow:var(--shadow-md)}button:active:not(:disabled){transform:translateY(0)}button:disabled{opacity:.6;cursor:not-allowed}button:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}button.secondary{background:transparent;color:var(--color-primary-600);box-shadow:none;border:1px solid var(--color-gray-300)}button.secondary:hover:not(:disabled){background:var(--color-primary-50);border-color:var(--color-primary-600);transform:none}button.danger{background:var(--color-error)}button.danger:hover:not(:disabled){background:#dc2626}form{display:flex;gap:var(--space-2);align-items:center;margin-bottom:var(--space-3)}@media(max-width:768px){form{flex-direction:column;align-items:stretch;gap:var(--space-3)}form button{width:100%}}label{display:flex;flex-direction:column;gap:var(--space-1);font-size:.875rem;font-weight:500;color:var(--color-gray-700)}label small{font-weight:400;color:var(--color-gray-500);font-size:.75rem}input,select{background:#fff;border:1px solid var(--color-gray-300);border-radius:var(--radius-sm);padding:.625rem .75rem;font-size:.875rem;transition:all .15s ease}input:focus,select:focus{border-color:var(--color-primary-500);outline:none;box-shadow:0 0 0 3px var(--color-primary-100)}input::placeholder{color:var(--color-gray-400)}input:disabled,select:disabled{background:var(--color-gray-100);cursor:not-allowed}table{width:100%;border-collapse:collapse;margin-top:var(--space-3);background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm)}@media(max-width:768px){.table-wrapper{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}table{min-width:600px;font-size:.8125rem}}thead{background:linear-gradient(180deg,#fafafa,#f5f5f5)}th,td{padding:var(--space-3) var(--space-4);font-size:.875rem;border-bottom:1px solid var(--color-gray-200);text-align:left}th{font-weight:600;color:var(--color-gray-700);text-transform:uppercase;font-size:.75rem;letter-spacing:.05em}tbody tr{transition:all .15s ease}tbody tr:hover{background:var(--color-gray-50);transform:scale(1.001)}tbody tr:last-child td{border-bottom:none}.money{font-variant-numeric:tabular-nums;font-weight:500}.money.negative{color:var(--color-error)}.money.positive{color:var(--color-success)}span[ondblclick]{padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease}span[ondblclick]:hover{background:var(--color-primary-50);box-shadow:inset 0 0 0 1px var(--color-primary-200)}input[type=text],input[type=number]{min-width:100px}nav{display:flex;gap:var(--space-2);margin-bottom:var(--space-3);flex-wrap:wrap}nav button{background:transparent;color:var(--color-primary-600);padding:var(--space-1) var(--space-2);font-size:.875rem;box-shadow:none;border:1px solid transparent}nav button:hover{background:var(--color-primary-50);border-color:var(--color-primary-200)}.sidebar-item{padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;transition:all .15s ease;color:var(--color-gray-700)}.sidebar-item:hover{background:var(--color-gray-100);color:var(--color-gray-900);transform:translate(2px)}.sidebar-category{display:flex;justify-content:space-between;align-items:center;gap:var(--space-2);padding:var(--space-2) 0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:8px}::-webkit-scrollbar-track{background:transparent}table{margin-top:12px}.lookup{position:relative;flex:1}.lookup input{width:100%}.lookup-menu{position:absolute;z-index:50;top:100%;left:0;right:0;background:#fff;border:1px solid #e5e7eb;border-radius:6px;margin-top:4px;max-height:200px;overflow-y:auto;box-shadow:0 10px 24px #0000001f}.lookup-item,.lookup-create{padding:8px 10px;font-size:13px;cursor:pointer}.lookup-item:hover{background:#f3f4f6}.lookup-create{background:#eff6ff;color:#1d4ed8;font-weight:500}.lookup-create:hover{background:#dbeafe}.editable-cell{display:inline-block;padding:2px 4px;border-radius:4px;cursor:pointer}.editable-cell{padding:2px 4px;border-radius:4px;cursor:pointer}.editable-cell:hover{background:#eef2ff}td input{width:100%;font-size:13px}.transaction-form{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.form-notice{width:100%;padding:12px 16px;background:#fef3c7;border:1px solid #fbbf24;border-radius:8px;margin:8px 0}.form-notice p{margin:0;font-size:.875rem;color:#92400e;line-height:1.5}.kind-toggle{display:flex;border:1px solid #d1d5db;border-radius:6px;overflow:hidden}.kind-toggle button{background:transparent;border:none;padding:6px 10px;font-size:13px;cursor:pointer;color:#374151}.kind-toggle button.active{font-weight:600}.kind-toggle button.expense.active{background:#fee2e2;color:#991b1b}.kind-toggle button.income.active{background:#dcfce7;color:#166534}.cleared-toggle{background:transparent;border:none;cursor:pointer;font-size:14px;color:#9ca3af}.cleared-toggle.cleared{color:#16a34a}tr.is-cleared{opacity:.65}.budget-bar{margin-top:4px}.budget-bar-header{font-size:12px;color:#374151;margin-bottom:2px}.budget-bar-track{height:6px;background:#e5e7eb;border-radius:999px;overflow:hidden}.budget-bar-fill{height:100%;transition:width .2s ease}.budget-bar-fill.ok{background:#22c55e}.budget-bar-fill.warn{background:#f59e0b}.budget-bar-fill.over{background:#dc2626}.sidebar-category{padding:6px 8px;border-radius:6px;cursor:pointer}.sidebar-category:hover{background:#f3f4f6}.sidebar{height:100vh;overflow:hidden;background:#fff;border-right:1px solid #e5e7eb;padding:16px;box-sizing:border-box}.layout.mobile .sidebar{overflow:hidden}.sidebar-content{height:100%;overflow:hidden}.sidebar-account{display:flex;justify-content:space-between;align-items:center;gap:8px}.sidebar-account .money{font-size:12px}.sidebar{height:100vh;overflow:hidden;background:#fff;border-right:1px solid #e5e7eb;padding:16px 20px 16px 12px;box-sizing:border-box}.sidebar-item,.sidebar-category{padding:6px 8px;margin-right:8px;border-radius:6px;cursor:pointer}.sidebar-account{display:grid;grid-template-columns:1fr auto;align-items:center;column-gap:12px}.sidebar-account .money{text-align:right;padding-right:4px}.sidebar-category-header{display:grid;grid-template-columns:1fr auto;align-items:center;margin-bottom:4px;padding-right:4px}.sidebar-actions{margin-top:8px;padding-top:8px;border-top:1px dashed #e5e7eb;display:flex;flex-direction:column;gap:4px}.sidebar-action{background:transparent;border:none;padding:6px 8px;font-size:13px;text-align:left;cursor:pointer;color:#2563eb;border-radius:6px}.sidebar-action:hover{background:#eff6ff}.sidebar-category-header{display:grid;grid-template-columns:1fr auto;align-items:center;column-gap:12px}.sidebar-category-header .editable-cell{font-size:12px;font-variant-numeric:tabular-nums}.sidebar-category-header input{width:80px;font-size:12px;text-align:right}.sidebar-action-inline{background:transparent;border:none;color:#2563eb;font-size:12px;cursor:pointer}.sidebar-category-header{display:flex;justify-content:space-between;align-items:center}.edit-icon{background:transparent;border:none;cursor:pointer;opacity:0;font-size:12px}.sidebar-category:hover .edit-icon{opacity:1}@media(hover:none){.edit-icon{opacity:1}}.sidebar-period{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px;margin-right:16px}.sidebar-period label{display:flex;flex-direction:column;font-size:12px;color:#374151}.sidebar-period input{padding:4px 6px;font-size:12px}.sidebar-month-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-weight:600}.sidebar-month-nav button{background:transparent;border:none;cursor:pointer;font-size:16px}@media(max-width:768px){.layout{height:100dvh}.content{padding:var(--space-3)}.modal{min-width:auto;max-width:calc(100vw - var(--space-6));max-height:calc(100dvh - var(--space-6));overflow-y:auto;border-radius:var(--radius-md)}.modal-body{max-height:calc(100dvh - 200px);overflow-y:auto;-webkit-overflow-scrolling:touch}button{min-height:44px;min-width:44px;padding:var(--space-3) var(--space-4);font-size:1rem}input,select,textarea{min-height:44px;font-size:16px}.modal-actions{flex-direction:column;gap:var(--space-2)}.modal-actions button{width:100%}input[type=date],input[type=month]{font-size:1rem!important;padding:12px 14px!important}.topbar-muted{display:none}.modal form label{margin-bottom:var(--space-4)}table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap}thead,tbody,tr{display:table;width:100%;table-layout:fixed}th,td{font-size:.875rem;padding:var(--space-2) var(--space-3)}}@media(max-width:480px){body{font-size:14px}.content{padding:var(--space-2)}.modal{max-width:100vw;max-height:100dvh;padding:0}.modal h3{font-size:1.125rem}button{padding:var(--space-2) var(--space-3);font-size:.9375rem}input,select,textarea{padding:var(--space-2)}form>label{margin-bottom:var(--space-3)}th,td{font-size:.8125rem;padding:var(--space-1) var(--space-2)}.hide-mobile{display:none}}.warning-box{display:flex;align-items:flex-start;gap:12px;padding:16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#991b1b;margin-top:16px}.warning-box svg{flex-shrink:0;margin-top:2px}.warning-box p{margin:0;font-size:14px;line-height:1.5}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--color-gray-200)}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-gray-900)}.close-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--color-gray-500);border-radius:6px;cursor:pointer;transition:all .2s}.close-button:hover{background:var(--color-gray-100);color:var(--color-gray-900)}.modal-body{padding:24px;max-height:60vh;overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--color-gray-200);background:var(--color-gray-50)}.primary-button{padding:10px 20px;background:var(--color-primary-600);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.primary-button:hover:not(:disabled){background:var(--color-primary-700)}.secondary-button{padding:10px 20px;background:#fff;color:var(--color-gray-700);border:1px solid var(--color-gray-300);border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.secondary-button:hover:not(:disabled){background:var(--color-gray-50)}.danger-button{padding:10px 20px;background:var(--color-error);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.danger-button:hover:not(:disabled){background:#dc2626}button:disabled{opacity:.5;cursor:not-allowed}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;font-size:14px;color:var(--color-gray-900)}.form-group select,.form-group input{width:100%;padding:10px 12px;border:1px solid var(--color-gray-300);border-radius:8px;font-size:14px;color:var(--color-gray-900);background:#fff;transition:all .2s}.form-group select:focus,.form-group input:focus{outline:none;border-color:var(--color-primary-600);box-shadow:0 0 0 3px #8b5cf61a}.form-group select:disabled,.form-group input:disabled{background:var(--color-gray-50);cursor:not-allowed}@media(-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}table,.modal,.sidebar,button,input,select{border-width:.5px}}.split-transaction-modal{width:600px;max-width:90vw;max-height:90vh;display:flex;flex-direction:column}.transaction-summary{background:#f8f9fa;padding:16px;border-radius:8px;margin-bottom:24px}.summary-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.summary-row+.summary-row{border-top:1px solid #e8e8e8}.summary-label{font-size:.875rem;color:#6b6b6b;font-weight:600}.summary-value{font-size:1rem;color:#1a1a1a;font-weight:700}.summary-row.warning{background:#fff9f0;padding:8px 12px;margin:8px -12px 0;border-radius:4px}.summary-row.warning .summary-label,.summary-row.warning .summary-value{color:#f59e0b}.summary-row.error{background:#fef2f2;padding:8px 12px;margin:8px -12px 0;border-radius:4px}.summary-row.error .summary-label,.summary-row.error .summary-value{color:#ef4444}.split-form{display:flex;flex-direction:column;gap:16px;flex:1;overflow:hidden}.splits-list{display:flex;flex-direction:column;gap:16px;overflow-y:auto;max-height:400px;padding:4px}.split-item{background:#fff;border:1px solid #e8e8e8;border-radius:8px;padding:16px}.split-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.split-number{font-size:.875rem;font-weight:700;color:#1a1a1a;text-transform:uppercase;letter-spacing:.05em}.remove-split-btn{background:transparent;border:none;color:#ef4444;cursor:pointer;padding:4px;border-radius:4px;transition:background .15s ease;display:flex;align-items:center;justify-content:center}.remove-split-btn:hover{background:#fef2f2}.split-fields{display:grid;gap:12px}.split-fields label{display:flex;flex-direction:column;gap:4px;font-size:.875rem;font-weight:600;color:#1a1a1a}.split-fields input,.split-fields select{padding:10px 12px;border:1px solid #e8e8e8;border-radius:8px;font-size:.9375rem;transition:border-color .15s ease}.split-fields input:focus,.split-fields select:focus{outline:none;border-color:#6b8e23}.add-split-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;background:transparent;border:2px dashed #e8e8e8;border-radius:8px;color:#6b6b6b;font-weight:600;cursor:pointer;transition:all .15s ease}.add-split-btn:hover:not(:disabled){border-color:#6b8e23;color:#6b8e23;background:#fff9f5}.add-split-btn:disabled{opacity:.5;cursor:not-allowed}.modal-actions{display:flex;gap:12px;padding-top:16px;border-top:1px solid #e8e8e8}.remove-all-btn{padding:12px 24px;background:transparent;border:1px solid #ef4444;border-radius:8px;color:#ef4444;font-weight:600;cursor:pointer;transition:all .15s ease}.remove-all-btn:hover:not(:disabled){background:#fef2f2}.submit-btn{flex:1;padding:12px 24px;background:#1a1a1a;border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:background .15s ease}.submit-btn:hover:not(:disabled){background:#2d2d2d}.submit-btn:disabled,.remove-all-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.split-transaction-modal{width:100%;max-height:85vh}.splits-list{max-height:300px}.split-fields{grid-template-columns:1fr}.modal-actions{flex-direction:column}}
