.category-selector{position:relative;width:100%}.category-selector-input-container{display:flex;flex-wrap:nowrap;align-items:center;gap:3px;padding:.5rem .75rem;border:1px solid var(--border-primary);border-radius:8px;background:var(--bg-primary);min-height:38px;height:38px;cursor:text;color:var(--text-primary);overflow-x:auto;overflow-y:hidden}.form-group .category-selector-input-container{border:1px solid var(--border-secondary)!important;border-radius:6px!important;padding:10px 12px!important;min-height:auto!important}.form-group .category-selector-input-container:focus-within{border-color:var(--text-accent)!important;box-shadow:0 0 0 3px #2563eb1a!important}.category-selector-input-container:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-primary-20)}.category-selector .category-tag{display:inline-flex!important;align-items:center;gap:2px;padding:2px 6px!important;background:#eff6ff!important;color:#1e40af!important;border-radius:3px!important;font-size:.75rem!important;font-weight:500;white-space:nowrap;border:1px solid rgba(30,64,175,.2)!important;line-height:1;height:20px;flex-shrink:0}.category-selector .category-tag-remove{background:none!important;border:none!important;color:#1e40af!important;font-size:12px!important;font-weight:700;cursor:pointer;padding:0;margin:0;line-height:1;border-radius:50%;width:14px;height:14px;display:flex;align-items:center;justify-content:center;opacity:.8}.category-selector .category-tag-remove:hover{opacity:1!important;color:#1d4ed8!important;background:#1e40af1a!important}.category-input{border:none;outline:none;background:transparent;flex:1;min-width:120px;font-size:.875rem;color:var(--text-primary)!important;padding:0;line-height:1.2;height:auto}.category-input::placeholder{color:var(--text-muted)!important}.category-clear-button{background:none;border:none;color:var(--text-secondary);font-size:16px;cursor:pointer;padding:0;margin:0;border-radius:2px;display:flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0;line-height:1;align-self:center}.category-clear-button:hover{color:var(--text-primary);background:var(--bg-secondary)}.category-suggestions{position:absolute;top:100%;left:0;right:0;z-index:9999;background:var(--bg-primary);border:1px solid var(--border-primary);border-top:none;border-bottom-left-radius:4px;border-bottom-right-radius:4px;box-shadow:0 4px 6px var(--shadow-light);max-height:200px;overflow-y:auto}.category-suggestion{display:block;width:100%;padding:.5rem .75rem;border:none;background:none;text-align:left;font-size:.875rem;color:var(--text-primary);cursor:pointer;border-bottom:1px solid var(--border-light)}.category-suggestion:hover{background:var(--bg-hover)}.category-suggestion:last-child{border-bottom:none}.category-suggestion.category-create{background:#2563eb0d;color:#2563eb;font-weight:500;border-bottom:1px solid rgba(37,99,235,.2)}.category-suggestion.category-create:hover:not(:disabled){background:#2563eb1a}.category-suggestion.category-create:disabled{opacity:.6;cursor:not-allowed}.no-suggestions{padding:.5rem .75rem;color:var(--text-secondary);font-size:.875rem;text-align:center}.category-selector.multiple .category-input{min-width:80px}.category-selector.variant-default .category-selector-input-container,.category-selector.single .category-selector-input-container{padding:.5rem!important;min-height:32px!important;height:32px!important;border-radius:6px!important;align-items:center!important}.category-selector.variant-default .category-input,.category-selector.single .category-input{font-size:.75rem!important;line-height:1.2!important;align-self:center}.category-selector.variant-default .category-clear-button,.category-selector.single .category-clear-button{margin-left:auto}.category-selector.variant-form .category-selector-input-container{border:1px solid rgba(255,255,255,.23)!important;border-radius:4px!important;padding:7px 14px!important;min-height:38px!important;height:55px!important;font-size:14px!important;background:transparent!important;color:var(--text-primary)!important;transition:border-color .2s cubic-bezier(0,0,.2,1) 0ms!important;box-sizing:border-box!important}.category-selector.variant-form .category-selector-input-container:hover{border-color:#fff!important}.category-selector.variant-form .category-selector-input-container:focus-within{border-color:#90caf9!important;border-width:2px!important;box-shadow:none!important}.category-selector.variant-form .category-selector-input-container .category-input{font-size:16px!important;line-height:1.5!important;color:var(--text-primary)!important;background:transparent!important}.category-selector.variant-form .category-selector-input-container .category-input::placeholder{color:var(--text-muted)!important}.category-selector.variant-form .category-suggestions{border:1px solid var(--border-secondary)!important;border-top:none!important;background:var(--bg-primary)!important;box-shadow:0 5px 5px -3px var(--shadow-light),0 8px 10px 1px var(--shadow-light),0 3px 14px 2px var(--shadow-light)!important}.category-selector.variant-form .category-suggestion{color:var(--text-primary)!important;background:var(--bg-primary)!important}.category-selector.variant-form .category-suggestion:hover{background:var(--bg-tertiary)!important}.category-selector.variant-filter .category-selector-input-container{border:1px solid var(--border-primary)!important;border-radius:8px!important;padding:.5rem .75rem!important;min-height:38px!important;height:38px!important;background:var(--bg-primary)!important;transition:all .2s ease!important;box-shadow:0 1px 2px #0000000d;overflow-x:auto;overflow-y:hidden;flex-wrap:nowrap}.category-selector.variant-filter .category-selector-input-container:hover{border-color:var(--border-secondary)!important;box-shadow:0 2px 4px #0000000d}.category-selector.variant-filter .category-selector-input-container:focus-within{border-color:#3b82f6!important;box-shadow:0 0 0 3px #3b82f61a,0 1px 3px #0000001a!important;transform:translateY(-1px)}.category-selector.variant-filter .category-selector-input-container .category-input{font-size:.875rem!important;color:var(--text-primary)!important}.category-selector.variant-filter .category-selector-input-container .category-input::placeholder{color:var(--text-muted)!important}.category-selector.variant-filter .category-suggestions{border:1px solid var(--border-secondary)!important;border-top:none!important;border-radius:0 0 4px 4px!important;box-shadow:0 4px 6px var(--shadow-light)!important}input.category-input,.category-selector .category-input,.category-selector-input-container .category-input,input[class*=category-input],*[class*=category-input]{color:var(--text-primary)!important}input.category-input::placeholder,.category-selector .category-input::placeholder,.category-selector-input-container .category-input::placeholder,input[class*=category-input]::placeholder,*[class*=category-input]::placeholder{color:var(--text-muted)!important}[data-theme=dark] .category-input,body.rs-theme-dark .category-input,.rs-theme-dark .category-input{color:#ffffffde!important}[data-theme=dark] .category-input::placeholder,body.rs-theme-dark .category-input::placeholder,.rs-theme-dark .category-input::placeholder{color:#fff9!important}.category-selector input{color:var(--text-primary)!important}.category-selector input::placeholder{color:var(--text-muted)!important}.MuiDialog-root .category-input,.MuiDialogContent-root .category-input,[role=dialog] .category-input,.MuiDialog-paper .category-input,.MuiDialog-container .category-input{color:var(--text-primary)!important;background-color:transparent!important}.MuiDialog-root .category-input::placeholder,.MuiDialogContent-root .category-input::placeholder,[role=dialog] .category-input::placeholder,.MuiDialog-paper .category-input::placeholder,.MuiDialog-container .category-input::placeholder{color:var(--text-muted)!important}.category-selector.variant-form input.category-input,.category-selector.variant-form .category-selector-input-container .category-input{color:var(--text-primary)!important}.category-selector.variant-form input.category-input::placeholder,.category-selector.variant-form .category-selector-input-container .category-input::placeholder{color:var(--text-muted)!important}.category-selector.variant-filter input.category-input,.category-selector.variant-filter .category-selector-input-container .category-input{color:var(--text-primary)!important}.category-selector.variant-filter input.category-input::placeholder,.category-selector.variant-filter .category-selector-input-container .category-input::placeholder{color:var(--text-muted)!important}.modal-content .category-selector .category-input,.form-group .category-selector .category-input,div.category-selector div.category-selector-input-container input.category-input{color:var(--text-primary)!important}.modal-content .category-selector .category-input::placeholder,.form-group .category-selector .category-input::placeholder,div.category-selector div.category-selector-input-container input.category-input::placeholder{color:var(--text-muted)!important}.MuiDialog-root .MuiDialogContent-root .category-selector.variant-form .category-selector-input-container .category-input{color:var(--text-primary)!important;background-color:transparent!important}.MuiDialog-root .MuiDialogContent-root .category-selector.variant-form .category-selector-input-container .category-input::placeholder{color:var(--text-muted)!important}[data-theme=dark] .MuiDialog-root .category-input,body.rs-theme-dark .MuiDialog-root .category-input,.rs-theme-dark .MuiDialog-root .category-input{color:#ffffffde!important}.rdp-root{--rdp-accent-color: blue;--rdp-accent-background-color: #f0f0ff;--rdp-day-height: 44px;--rdp-day-width: 44px;--rdp-day_button-border-radius: 100%;--rdp-day_button-border: 2px solid transparent;--rdp-day_button-height: 42px;--rdp-day_button-width: 42px;--rdp-selected-border: 2px solid var(--rdp-accent-color);--rdp-disabled-opacity: .5;--rdp-outside-opacity: .75;--rdp-today-color: var(--rdp-accent-color);--rdp-dropdown-gap: .5rem;--rdp-months-gap: 2rem;--rdp-nav_button-disabled-opacity: .5;--rdp-nav_button-height: 2.25rem;--rdp-nav_button-width: 2.25rem;--rdp-nav-height: 2.75rem;--rdp-range_middle-background-color: var(--rdp-accent-background-color);--rdp-range_middle-color: inherit;--rdp-range_start-color: white;--rdp-range_start-background: linear-gradient( var(--rdp-gradient-direction), transparent 50%, var(--rdp-range_middle-background-color) 50% );--rdp-range_start-date-background-color: var(--rdp-accent-color);--rdp-range_end-background: linear-gradient( var(--rdp-gradient-direction), var(--rdp-range_middle-background-color) 50%, transparent 50% );--rdp-range_end-color: white;--rdp-range_end-date-background-color: var(--rdp-accent-color);--rdp-week_number-border-radius: 100%;--rdp-week_number-border: 2px solid transparent;--rdp-week_number-height: var(--rdp-day-height);--rdp-week_number-opacity: .75;--rdp-week_number-width: var(--rdp-day-width);--rdp-weeknumber-text-align: center;--rdp-weekday-opacity: .75;--rdp-weekday-padding: .5rem 0rem;--rdp-weekday-text-align: center;--rdp-gradient-direction: 90deg;--rdp-animation_duration: .3s;--rdp-animation_timing: cubic-bezier(.4, 0, .2, 1)}.rdp-root[dir=rtl]{--rdp-gradient-direction: -90deg}.rdp-root[data-broadcast-calendar=true]{--rdp-outside-opacity: unset}.rdp-root{position:relative;box-sizing:border-box}.rdp-root *{box-sizing:border-box}.rdp-day{width:var(--rdp-day-width);height:var(--rdp-day-height);text-align:center}.rdp-day_button{background:none;padding:0;margin:0;cursor:pointer;font:inherit;color:inherit;justify-content:center;align-items:center;display:flex;width:var(--rdp-day_button-width);height:var(--rdp-day_button-height);border:var(--rdp-day_button-border);border-radius:var(--rdp-day_button-border-radius)}.rdp-day_button:disabled{cursor:revert}.rdp-caption_label{z-index:1;position:relative;display:inline-flex;align-items:center;white-space:nowrap;border:0}.rdp-dropdown:focus-visible~.rdp-caption_label{outline:5px auto Highlight;outline:5px auto -webkit-focus-ring-color}.rdp-button_next,.rdp-button_previous{border:none;background:none;padding:0;margin:0;cursor:pointer;font:inherit;color:inherit;-moz-appearance:none;-webkit-appearance:none;display:inline-flex;align-items:center;justify-content:center;position:relative;appearance:none;width:var(--rdp-nav_button-width);height:var(--rdp-nav_button-height)}.rdp-button_next:disabled,.rdp-button_next[aria-disabled=true],.rdp-button_previous:disabled,.rdp-button_previous[aria-disabled=true]{cursor:revert;opacity:var(--rdp-nav_button-disabled-opacity)}.rdp-chevron{display:inline-block;fill:var(--rdp-accent-color)}.rdp-root[dir=rtl] .rdp-nav .rdp-chevron{transform:rotate(180deg);transform-origin:50%}.rdp-dropdowns{position:relative;display:inline-flex;align-items:center;gap:var(--rdp-dropdown-gap)}.rdp-dropdown{z-index:2;opacity:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;position:absolute;inset-block-start:0;inset-block-end:0;inset-inline-start:0;width:100%;margin:0;padding:0;cursor:inherit;border:none;line-height:inherit}.rdp-dropdown_root{position:relative;display:inline-flex;align-items:center}.rdp-dropdown_root[data-disabled=true] .rdp-chevron{opacity:var(--rdp-disabled-opacity)}.rdp-month_caption{display:flex;align-content:center;height:var(--rdp-nav-height);font-weight:700;font-size:large}.rdp-root[data-nav-layout=around] .rdp-month,.rdp-root[data-nav-layout=after] .rdp-month{position:relative}.rdp-root[data-nav-layout=around] .rdp-month_caption{justify-content:center;margin-inline-start:var(--rdp-nav_button-width);margin-inline-end:var(--rdp-nav_button-width);position:relative}.rdp-root[data-nav-layout=around] .rdp-button_previous{position:absolute;inset-inline-start:0;top:0;height:var(--rdp-nav-height);display:inline-flex}.rdp-root[data-nav-layout=around] .rdp-button_next{position:absolute;inset-inline-end:0;top:0;height:var(--rdp-nav-height);display:inline-flex;justify-content:center}.rdp-months{position:relative;display:flex;flex-wrap:wrap;gap:var(--rdp-months-gap);max-width:fit-content}.rdp-month_grid{border-collapse:collapse}.rdp-nav{position:absolute;inset-block-start:0;inset-inline-end:0;display:flex;align-items:center;height:var(--rdp-nav-height)}.rdp-weekday{opacity:var(--rdp-weekday-opacity);padding:var(--rdp-weekday-padding);font-weight:500;font-size:smaller;text-align:var(--rdp-weekday-text-align);text-transform:var(--rdp-weekday-text-transform)}.rdp-week_number{opacity:var(--rdp-week_number-opacity);font-weight:400;font-size:small;height:var(--rdp-week_number-height);width:var(--rdp-week_number-width);border:var(--rdp-week_number-border);border-radius:var(--rdp-week_number-border-radius);text-align:var(--rdp-weeknumber-text-align)}.rdp-today:not(.rdp-outside){color:var(--rdp-today-color)}.rdp-selected{font-weight:700;font-size:large}.rdp-selected .rdp-day_button{border:var(--rdp-selected-border)}.rdp-outside{opacity:var(--rdp-outside-opacity)}.rdp-disabled:not(.rdp-selected){opacity:var(--rdp-disabled-opacity)}.rdp-hidden{visibility:hidden;color:var(--rdp-range_start-color)}.rdp-range_start{background:var(--rdp-range_start-background)}.rdp-range_start .rdp-day_button{background-color:var(--rdp-range_start-date-background-color);color:var(--rdp-range_start-color)}.rdp-range_middle{background-color:var(--rdp-range_middle-background-color)}.rdp-range_middle .rdp-day_button{border:unset;border-radius:unset;color:var(--rdp-range_middle-color)}.rdp-range_end{background:var(--rdp-range_end-background);color:var(--rdp-range_end-color)}.rdp-range_end .rdp-day_button{color:var(--rdp-range_start-color);background-color:var(--rdp-range_end-date-background-color)}.rdp-range_start.rdp-range_end{background:revert}.rdp-focusable{cursor:pointer}@keyframes rdp-slide_in_left{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes rdp-slide_in_right{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes rdp-slide_out_left{0%{transform:translate(0)}to{transform:translate(-100%)}}@keyframes rdp-slide_out_right{0%{transform:translate(0)}to{transform:translate(100%)}}.rdp-weeks_before_enter{animation:rdp-slide_in_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-weeks_before_exit{animation:rdp-slide_out_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-weeks_after_enter{animation:rdp-slide_in_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-weeks_after_exit{animation:rdp-slide_out_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-root[dir=rtl] .rdp-weeks_after_enter{animation:rdp-slide_in_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-root[dir=rtl] .rdp-weeks_before_exit{animation:rdp-slide_out_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-root[dir=rtl] .rdp-weeks_before_enter{animation:rdp-slide_in_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-root[dir=rtl] .rdp-weeks_after_exit{animation:rdp-slide_out_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}@keyframes rdp-fade_in{0%{opacity:0}to{opacity:1}}@keyframes rdp-fade_out{0%{opacity:1}to{opacity:0}}.rdp-caption_after_enter{animation:rdp-fade_in var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-caption_after_exit{animation:rdp-fade_out var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-caption_before_enter{animation:rdp-fade_in var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-caption_before_exit{animation:rdp-fade_out var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.date-period-navigator{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.date-period-navigator *{box-sizing:border-box}.period-type-selector{display:inline-flex;align-items:center;gap:.25rem;background:transparent;padding:0;border-radius:0}.period-type-btn{background:transparent;border:none;padding:0 .875rem;margin:0;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text-secondary);transition:all .15s ease;min-width:3.75rem;text-align:center;height:2rem;display:inline-flex;align-items:center;justify-content:center}.period-type-btn:hover{color:var(--text-primary);background:#ffffff0d}.period-type-btn.active{background:var(--button-primary);color:#fff}.period-type-btn.active:hover{background:var(--button-primary-hover)}.period-type-btn:focus-visible{outline:2px solid var(--button-primary);outline-offset:2px}.period-navigation{display:flex;align-items:center;gap:.5rem}.nav-arrow{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:6px;padding:.375em;margin:0;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .15s ease}.nav-arrow svg{display:block;width:1.25em;height:1.25em}.nav-arrow:hover{background:var(--bg-hover, rgba(255, 255, 255, .08));border-color:var(--border-secondary, rgba(255, 255, 255, .15));color:var(--text-primary)}.nav-arrow:focus-visible{outline:2px solid var(--button-primary);outline-offset:2px}.nav-arrow:active{transform:scale(.95)}.period-label{font-size:.9375rem;font-weight:600;color:var(--text-primary);min-width:8.75rem;text-align:center;white-space:nowrap}.custom-picker-container{position:relative}.custom-picker-trigger{background:transparent;border:1px solid var(--border-primary);border-radius:6px;padding:.375rem .625rem;margin:0;cursor:pointer;font-size:.8125rem;font-weight:500;color:var(--text-secondary);display:flex;align-items:center;gap:.25rem;transition:all .15s ease}.custom-picker-trigger:hover{border-color:var(--border-secondary, rgba(255, 255, 255, .15));color:var(--text-primary)}.custom-picker-trigger.active{background:var(--button-primary);border-color:var(--button-primary);color:#fff}.custom-picker-trigger.active:hover{background:var(--button-primary-hover);border-color:var(--button-primary-hover)}.custom-picker-trigger:focus-visible{outline:2px solid var(--button-primary);outline-offset:2px}.custom-picker-chevron{transition:transform .2s ease}.custom-picker-chevron.open{transform:rotate(180deg)}.custom-picker-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;z-index:1000;background:var(--bg-elevated, var(--bg-primary));border:1px solid var(--border-primary);border-radius:12px;box-shadow:0 12px 40px #0006;padding:0;overflow:hidden}.date-picker-layout{display:flex}.preset-panel{display:flex;flex-direction:column;padding:.75rem;background:var(--bg-tertiary);border-right:1px solid var(--border-primary);min-width:130px}.preset-btn{background:transparent;border:none;padding:.5rem .75rem;margin:0;border-radius:6px;cursor:pointer;font-size:.8125rem;font-weight:500;color:var(--text-secondary);text-align:left;transition:all .15s ease;white-space:nowrap}.preset-btn:hover{background:#ffffff14;color:var(--text-primary)}.preset-btn:focus-visible{outline:2px solid var(--button-primary);outline-offset:-2px}.calendar-panel{padding:.75rem}.calendar-panel .rdp-root{--rdp-accent-color: var(--button-primary);--rdp-accent-background-color: var(--button-primary);--rdp-day-height: 36px;--rdp-day-width: 36px;--rdp-selected-font: 600 .875rem system-ui;--rdp-outside-opacity: .4;--rdp-range_start-color: white;--rdp-range_start-background: var(--button-primary);--rdp-range_start-date-background-color: var(--button-primary);--rdp-range_end-color: white;--rdp-range_end-background: var(--button-primary);--rdp-range_end-date-background-color: var(--button-primary);--rdp-range_middle-background-color: rgba(59, 130, 246, .2);--rdp-range_middle-color: var(--text-primary);margin:0;font-family:inherit}.calendar-panel .rdp-month_caption{display:flex;align-items:center;justify-content:center;padding:0 0 .5rem;margin-bottom:.5rem;border-bottom:1px solid var(--border-primary)}.calendar-panel .rdp-caption_label{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.calendar-panel .rdp-nav{display:flex;gap:.25rem}.calendar-panel .rdp-button_previous,.calendar-panel .rdp-button_next{width:28px;height:28px;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .15s ease}.calendar-panel .rdp-button_previous:hover,.calendar-panel .rdp-button_next:hover{background:var(--bg-hover, rgba(255, 255, 255, .08));border-color:var(--border-secondary);color:var(--text-primary)}.calendar-panel .rdp-chevron{fill:currentColor;width:14px;height:14px}.calendar-panel .rdp-weekday{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;padding:.5rem 0;width:var(--rdp-day-width);text-align:center}.calendar-panel .rdp-day{width:var(--rdp-day-width);height:var(--rdp-day-height);font-size:.875rem;font-weight:500;color:var(--text-primary);transition:all .15s ease}.calendar-panel .rdp-day_button{width:100%;height:100%;border-radius:8px;border:none;background:transparent;cursor:pointer;font:inherit;color:inherit;transition:all .15s ease}.calendar-panel .rdp-day_button:hover{background:#ffffff14}.calendar-panel .rdp-outside .rdp-day_button{color:var(--text-muted);opacity:.5}.calendar-panel .rdp-disabled .rdp-day_button{color:var(--text-muted);opacity:.3;cursor:not-allowed}.calendar-panel .rdp-today .rdp-day_button{font-weight:700;color:var(--button-primary)}.calendar-panel .rdp-selected .rdp-day_button{background:var(--button-primary);color:#fff;font-weight:600}.calendar-panel .rdp-range_start .rdp-day_button{background:var(--button-primary);color:#fff;border-top-right-radius:0;border-bottom-right-radius:0}.calendar-panel .rdp-range_end .rdp-day_button{background:var(--button-primary);color:#fff;border-top-left-radius:0;border-bottom-left-radius:0}.calendar-panel .rdp-range_start.rdp-range_end .rdp-day_button{border-radius:8px}.calendar-panel .rdp-range_middle .rdp-day_button{background:#3b82f633;color:var(--text-primary);border-radius:0}.calendar-panel .rdp-range_middle .rdp-day_button:hover{background:#3b82f64d}@media (max-width: 768px){.date-period-navigator{flex-direction:column;align-items:stretch;gap:.5rem}.period-type-selector,.period-navigation{justify-content:center}.custom-picker-container{align-self:center}.custom-picker-dropdown{right:auto;left:50%;transform:translate(-50%)}.date-picker-layout{flex-direction:column}.preset-panel{flex-direction:row;flex-wrap:wrap;border-right:none;border-bottom:1px solid var(--border-primary);min-width:auto;gap:.25rem}.preset-btn{padding:.375rem .625rem;font-size:.75rem}}@media (max-width: 480px){.period-type-btn{padding:.375rem .625rem;font-size:.8125rem;min-width:3.125rem}.period-label{font-size:.875rem;min-width:7.5rem}.nav-arrow{padding:.25em}.calendar-panel .rdp-root{--rdp-day-width: 32px;--rdp-day-height: 32px}}.account-selector{width:100%}.account-selector-dropdown{width:100%;padding:10px 12px;border:1px solid var(--border-secondary);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-family:inherit;cursor:pointer;transition:all .2s ease}.account-selector-dropdown:hover{border-color:var(--border-primary)}.account-selector-dropdown:focus{outline:none;border-color:var(--text-accent);box-shadow:0 0 0 3px #2563eb1a}.account-selector-dropdown:disabled{background-color:var(--bg-secondary);cursor:not-allowed;opacity:.6}.account-selector-dropdown option{padding:8px}.preview-loading{margin-top:.5rem;padding:.5rem;background-color:#f0f0f0;border-radius:4px;font-size:.875rem;color:#666}.preview-match{margin-top:.5rem;padding:.75rem;background-color:#e8f5e9;border-left:3px solid #4caf50;border-radius:4px;font-size:.875rem;color:#2e7d32;line-height:1.5}.preview-category{font-weight:600;color:#1b5e20}.preview-counterparty{font-weight:600;color:#1565c0}.preview-pattern{font-style:italic;color:#555;font-size:.8rem}.pagination-container{display:flex;flex-direction:column;gap:16px;align-items:center;width:100%}.pagination-info{display:flex;align-items:center;gap:16px;font-size:.875rem;color:var(--text-secondary)}.page-size-select{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;padding:4px 8px;font-size:.875rem;color:var(--text-primary);cursor:pointer;transition:border-color .2s}.page-size-select:focus{outline:none;border-color:var(--text-accent);box-shadow:0 0 0 3px #2563eb1a}.pagination-controls{display:flex;gap:8px;align-items:center}.pagination-button{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;padding:8px 12px;font-size:.875rem;color:var(--text-primary);cursor:pointer;transition:all .2s;min-width:40px;text-align:center}.pagination-button:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--text-accent)}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.pagination-button.active{background:var(--text-accent);color:var(--bg-primary);border-color:var(--text-accent)}.pagination-button.active:hover{background:var(--button-primary-hover)}@media (max-width: 768px){.pagination-container{gap:12px}.pagination-info{flex-direction:column;gap:8px;text-align:center}.pagination-controls{flex-wrap:wrap;justify-content:center}.pagination-button{padding:6px 10px;font-size:.8rem;min-width:36px}}.transactions-page{margin:0 auto;padding:1rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-secondary);min-height:100vh}.transactions-page .page-header{margin-bottom:1rem}.transactions-page .page-header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;flex-wrap:nowrap}.transactions-page .page-header-content>div:first-child{flex:1}.transactions-page .page-header-content .button-primary{white-space:nowrap;padding:.5rem 1rem;font-size:.875rem;flex-shrink:0;width:auto;max-width:fit-content}.transactions-page .page-header h1{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem;text-align:left}.transactions-page .page-description{font-size:.875rem;color:var(--text-muted);margin:0;text-align:left}.transactions-page .error-message{background-color:#fee2e2;border:1px solid #fca5a5;color:#dc2626;padding:1rem;border-radius:8px;margin-bottom:2rem}.success-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center}.success-icon{width:64px;height:64px;border-radius:50%;background-color:#10b981;color:#fff;display:flex;align-items:center;justify-content:center;font-size:32px;margin-bottom:1rem}.success-message p{font-size:1.1rem;color:var(--text-primary);margin:0}.transactions-page .rule-filter-banner{background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:6px;margin-bottom:1rem}.transactions-page .rule-filter-content{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem}.transactions-page .rule-filter-text{font-size:.875rem;color:var(--text-primary)}.transactions-page .rule-filter-clear-btn{background:transparent;border:none;color:var(--text-muted);padding:.0625rem .125rem;border-radius:2px;cursor:pointer;font-size:.625rem;transition:all .2s ease;margin-left:.5rem;line-height:.875rem;min-width:auto;width:auto;height:auto;flex-shrink:0}.transactions-page .rule-filter-clear-btn:hover{background:#6b72801a;color:var(--text-primary)}@media (max-width: 768px){.transactions-page .rule-filter-content{flex-direction:column;gap:.5rem;text-align:center}}.transactions-page .transactions-layout{display:flex;flex-direction:column;gap:.75rem}.transactions-page .filters-sidebar{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:12px;padding:0;box-shadow:0 1px 3px var(--shadow-light);position:static;max-height:none;overflow:visible;width:100%}.transactions-page .transaction-filters-advanced{padding:.75rem 1rem;transition:padding .3s ease}.transactions-page .transaction-filters-advanced.collapsed{padding:.5rem 1rem}.transactions-page .filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:.25rem;border-bottom:1px solid var(--border-primary);flex-wrap:nowrap;min-height:28px;transition:all .3s ease;cursor:pointer}.transactions-page .transaction-filters-advanced.collapsed .filter-header{margin-bottom:0;padding-bottom:.5rem;min-height:24px}.transactions-page .transaction-filters-advanced.collapsed .filter-header{border-bottom:1px solid var(--border-secondary)}.transactions-page .filter-header h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0;flex-shrink:0;transition:font-size .3s ease}.transactions-page .transaction-filters-advanced.collapsed .filter-header h3{font-size:.875rem}.transactions-page .filter-header-actions{display:flex;align-items:center;gap:.75rem}.transactions-page .clear-all-button{background:#ef4444;color:#fff;border:none;padding:.375rem .75rem;border-radius:6px;font-size:.75rem;font-weight:500;cursor:pointer;transition:background-color .2s;flex-shrink:0;white-space:nowrap;min-width:auto;width:auto}.transactions-page .clear-all-button:hover{background:#dc2626}.transactions-page .collapse-toggle-button{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:6px;padding:.375rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:28px;height:28px}.transactions-page .collapse-toggle-button:hover{background:var(--bg-secondary);border-color:var(--border-secondary)}.transactions-page .collapse-chevron{font-size:.75rem;color:var(--text-muted);transition:transform .3s ease;transform:rotate(0)}.transactions-page .collapse-chevron.collapsed{transform:rotate(-90deg)}.transactions-page .filters-container{display:flex;flex-direction:column;gap:.75rem;animation:slideDown .3s ease-out;overflow:visible}@keyframes slideDown{0%{opacity:0;max-height:0;transform:translateY(-10px)}to{opacity:1;max-height:500px;transform:translateY(0)}}.transactions-page .filters-row{display:flex;gap:.75rem;align-items:start;flex-wrap:wrap}.transactions-page .primary-filters{background:linear-gradient(135deg,#3b82f608,#10b98108);border:1px solid var(--border-secondary);border-radius:12px;padding:.75rem}.transactions-page .secondary-filters{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;padding:.75rem;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.transactions-page .filter-group{display:flex;flex-direction:column;gap:.25rem;min-width:0}.transactions-page .search-group{flex:2;min-width:250px}.transactions-page .date-group,.transactions-page .amount-group{flex:1.5;min-width:200px}.transactions-page .options-group{flex:1;min-width:150px}.transactions-page .categories-group{flex:2;min-width:200px}.transactions-page .more-filters-toggle{display:inline-flex;align-items:center;justify-content:center;gap:.25rem;min-width:4.5rem;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:6px;padding:.375rem .625rem;font-size:.75rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;white-space:nowrap}.transactions-page .more-filters-toggle:hover{background:var(--bg-hover);border-color:var(--border-secondary);color:var(--text-primary)}.transactions-page .more-filters-toggle.active{background:var(--button-primary);border-color:var(--button-primary);color:#fff}.transactions-page .active-filters-badge{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 .25rem;background:var(--button-primary);color:#fff;border-radius:9999px;font-size:.625rem;font-weight:600}.transactions-page .filter-label{display:block;font-size:.75rem;font-weight:600;color:var(--text-secondary);margin-bottom:.25rem;letter-spacing:.025em}.transactions-page .filter-input{width:100%;padding:.5rem .75rem;height:38px;border:1px solid var(--border-primary);border-radius:8px;background-color:var(--bg-primary);font-size:.875rem;color:var(--text-primary);transition:all .2s ease;box-shadow:0 1px 2px #0000000d}.transactions-page .filter-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a,0 1px 3px #0000001a;transform:translateY(-1px)}.transactions-page .filter-input:hover{border-color:var(--border-secondary);box-shadow:0 2px 4px #0000000d}.transactions-page .filter-input::placeholder{color:var(--text-muted);font-style:italic}.transactions-page .search-input{width:100%;padding:.5rem .75rem;border:1px solid var(--border-primary);border-radius:8px;background-color:var(--bg-primary);font-size:.875rem;color:var(--text-primary);transition:border-color .2s,box-shadow .2s}.transactions-page .search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.transactions-page .search-input::placeholder{color:var(--text-muted)}.transactions-page .amount-range-inputs{display:flex;align-items:center;gap:.5rem}.transactions-page .amount-input{flex:1}.transactions-page .amount-separator{color:var(--text-secondary);font-weight:600;font-size:.875rem;white-space:nowrap;padding:0 .25rem;opacity:.7}.transactions-page .checkbox-container{display:flex;align-items:center;gap:.5rem}.transactions-page .checkbox-label{display:flex;align-items:center;gap:.375rem;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.75rem;color:var(--text-primary);font-weight:500}.transactions-page .checkbox-input{width:18px;height:18px;border:2px solid var(--border-primary);border-radius:4px;background-color:var(--bg-primary);cursor:pointer;transition:all .2s ease;position:relative;margin:0}.transactions-page .checkbox-input:checked{background-color:#3b82f6;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.transactions-page .checkbox-input:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:12px;font-weight:700}.transactions-page .checkbox-input:hover{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f60d}.transactions-page .checkbox-text{font-weight:500;letter-spacing:.025em}.transactions-page .amount-range{display:flex;align-items:center;gap:.5rem}.transactions-page .date-range-picker{position:relative}.transactions-page .date-range-button{width:100%;padding:.5rem .75rem;border:1px solid var(--border-primary);border-radius:8px;background-color:var(--bg-primary);font-size:.875rem;color:var(--text-primary);cursor:pointer;transition:border-color .2s,box-shadow .2s;display:flex;justify-content:space-between;align-items:center;text-align:left}.transactions-page .date-range-button:hover{border-color:var(--border-secondary)}.transactions-page .date-range-button:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.transactions-page .date-range-placeholder{color:var(--text-muted)}.transactions-page .date-range-chevron{color:var(--text-muted);font-size:.75rem;transition:transform .2s}.transactions-page .date-range-dropdown{position:absolute;top:100%;left:0;z-index:50;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;margin-top:.25rem;overflow:hidden;min-width:800px}.transactions-page .date-picker-actions{border-top:1px solid var(--border-primary);padding:1rem;text-align:right;display:flex;gap:.5rem;justify-content:flex-end}.transactions-page .date-clear-button{padding:.5rem 1rem;border:1px solid var(--border-primary);border-radius:6px;background:var(--bg-primary);color:var(--text-muted);font-size:.875rem;cursor:pointer;transition:all .2s}.transactions-page .date-clear-button:hover{background:var(--bg-tertiary);border-color:var(--border-secondary)}.transactions-page .date-apply-button{padding:.5rem 1rem;border:1px solid #3b82f6;border-radius:6px;background:#3b82f6;color:#fff;font-size:.875rem;cursor:pointer;transition:all .2s}.transactions-page .date-apply-button:hover{background:#2563eb;border-color:#2563eb}.transactions-page .rdrCalendarWrapper{background:var(--bg-primary);border:1px solid var(--border-primary);box-shadow:0 1px 3px var(--shadow-light)}.transactions-page .rdrCalendarWrapper *,.transactions-page .rdrDateRangeWrapper *{background-color:var(--bg-primary);color:var(--text-primary)}.transactions-page .rdrDateRangeWrapper{background:transparent}.transactions-page .rdrDefinedRangesWrapper{flex:0 0 200px;background:var(--bg-tertiary);border-right:1px solid var(--border-primary);border-radius:0}.transactions-page .rdrStaticRanges{border:none;background:transparent}.transactions-page .rdrStaticRange{border:none;background:transparent;margin-bottom:2px}.transactions-page .rdrStaticRangeLabel{background:transparent;color:var(--text-secondary);font-size:.875rem;padding:.5rem 1rem;border-radius:4px;margin:0 .5rem;transition:all .2s}.transactions-page .rdrStaticRangeLabel:hover{background:var(--bg-tertiary)}.transactions-page .rdrStaticRangeSelected .rdrStaticRangeLabel{background:var(--bg-accent);color:var(--text-accent)}.transactions-page .rdrInputRanges{border:none;background:transparent;padding:.5rem}.transactions-page .rdrInputRange{background:transparent;border:none;margin-bottom:.5rem}.transactions-page .rdrInputRangeInput{background:var(--bg-primary);border:1px solid var(--border-secondary);border-radius:4px;padding:.25rem .5rem;color:var(--text-primary);font-size:.875rem;margin:0 .25rem}.transactions-page .rdrDateDisplayWrapper{display:none}.transactions-page .rdrMonth{padding:0;margin:0 .5rem}.transactions-page .rdrMonthAndYearWrapper{background:var(--bg-tertiary);border-radius:6px;padding:.5rem;margin-bottom:1rem;text-align:center}.transactions-page .rdrMonthAndYearPickers{margin:0}.transactions-page .rdrMonthPicker select,.transactions-page .rdrYearPicker select{background:var(--bg-primary);border:1px solid var(--border-secondary);border-radius:4px;padding:.25rem .5rem;color:var(--text-primary);font-size:.875rem;margin:0 .25rem}.transactions-page .rdrNextPrevButton{background:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-secondary)}.transactions-page .rdrNextPrevButton:hover{background:var(--bg-secondary)}.transactions-page .rdrWeekDays{background:var(--bg-tertiary);border-bottom:1px solid var(--border-primary)}.transactions-page .rdrWeekDay{color:var(--text-muted);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;padding:.5rem}.transactions-page .rdrDays{background:transparent}.transactions-page .rdrDay{background:transparent;color:var(--text-primary)}.transactions-page .rdrDayNumber{color:var(--text-primary);font-weight:500;font-size:.875rem}.transactions-page .rdrDayToday .rdrDayNumber{background:#3b82f6;color:#fff;font-weight:600}.transactions-page .rdrDayInRange{background:#dbeafe;color:#1e40af}.transactions-page .rdrDayStartOfRange,.transactions-page .rdrDayEndOfRange{background:#dbeafe}.transactions-page .rdrDayStartOfRange .rdrDayNumber,.transactions-page .rdrDayEndOfRange .rdrDayNumber{background:#3b82f6;color:#fff;font-weight:600}.transactions-page .rdrDayInPreview{background:var(--bg-tertiary);color:var(--text-secondary)}.transactions-page .rdrDayHovered .rdrDayNumber{background:var(--bg-secondary);color:var(--text-primary)}.transactions-page .rdrDayPassive .rdrDayNumber{color:var(--text-muted)}.transactions-page .rdrDayDisabled .rdrDayNumber{color:var(--border-primary)}.transactions-page .filter-select{width:100%;padding:.5rem .75rem;height:38px;border:1px solid var(--border-primary);border-radius:8px;background-color:var(--bg-primary);font-size:.875rem;color:var(--text-primary);cursor:pointer;transition:border-color .2s,box-shadow .2s}.transactions-page .filter-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.transactions-page .category-tag-input{position:relative}.transactions-page .tag-input-container{min-height:42px;padding:.5rem;border:1px solid var(--border-primary);border-radius:8px;background-color:var(--bg-primary);display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;transition:border-color .2s,box-shadow .2s}.transactions-page .tag-input-container:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.transactions-page .category-input{flex:1;min-width:120px;border:none;outline:none;background:transparent;font-size:.875rem;color:var(--text-primary)}.transactions-page .category-input::placeholder{color:var(--text-muted)}.transactions-page .category-tag{display:inline-flex;align-items:center;background:var(--bg-accent);color:var(--text-accent);padding:.375rem .5rem;border-radius:6px;font-size:.75rem;font-weight:500;gap:.375rem;border:1px solid var(--border-secondary);line-height:1;flex-shrink:0}.transactions-page .category-tag-remove{background:none;border:none;color:var(--text-accent);font-size:1.5rem;font-weight:700;cursor:pointer;padding:0;margin:0;line-height:.8;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s;flex-shrink:0}.transactions-page .category-tag-remove:hover{background:var(--bg-tertiary);color:var(--text-primary)}.transactions-page .category-suggestions{position:absolute;top:100%;left:0;right:0;z-index:9999;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;margin-top:.25rem;max-height:200px;overflow-y:auto}.transactions-page .category-suggestion{width:100%;text-align:left;padding:.75rem 1rem;border:none;background:none;color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:background-color .2s;border-bottom:1px solid var(--border-secondary)}.transactions-page .category-suggestion:last-child{border-bottom:none}.transactions-page .category-suggestion:hover{background-color:var(--bg-tertiary)}.transactions-page .category-suggestion:focus{outline:none;background-color:var(--bg-accent)}.transactions-page .selected-categories,.transactions-page .no-categories-text,.transactions-page .add-category-button,.transactions-page .category-dropdown,.transactions-page .category-dropdown-header,.transactions-page .category-search-input,.transactions-page .clear-categories-button,.transactions-page .category-options,.transactions-page .category-option,.transactions-page .category-option-checkbox,.transactions-page .category-option-name,.transactions-page .no-categories-found{display:none}.transactions-page .transactions-content{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:12px;box-shadow:0 1px 3px var(--shadow-light);overflow:visible}.transactions-page .transactions-header{padding:.5rem .75rem;border-bottom:1px solid var(--border-primary);background-color:var(--bg-tertiary)}.transactions-page .transactions-summary{display:flex;justify-content:space-between;align-items:center}.transactions-page .transactions-summary h2{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.transactions-page .transactions-stats{display:flex;align-items:center;gap:1rem}.transactions-page .transaction-count,.transactions-page .transaction-total{font-size:.75rem;color:var(--text-muted);font-weight:500}.transactions-page .transaction-total .positive{color:var(--positive-amount);font-weight:600}.transactions-page .transaction-total .negative{color:var(--negative-amount);font-weight:600}.transactions-page .transactions-table-container{padding:0}.transactions-page .transaction-table{width:100%;background-color:var(--bg-primary)}.transactions-page .transaction-table h2{display:none}.transactions-page .transaction-table table{width:100%;border-collapse:collapse;table-layout:fixed;font-size:.8125rem;background-color:var(--bg-primary)}.transactions-page .transaction-table th,.transactions-page .transaction-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--border-primary);color:var(--text-primary);background-color:transparent;overflow:visible;position:relative}.transactions-page .transaction-table th:nth-child(3),.transactions-page .transaction-table td:nth-child(3){text-align:right}.transactions-page .transaction-table tr:hover,.transactions-page .transaction-table tr:hover td{background-color:var(--bg-tertiary)}.transactions-page .transaction-table .positive{color:var(--positive-amount);font-weight:600}.transactions-page .transaction-table .negative{color:var(--negative-amount);font-weight:600}.transactions-page .transaction-table select{padding:.5rem;border:1px solid var(--border-primary);border-radius:6px;background-color:var(--bg-primary);font-size:.875rem;color:var(--text-primary);cursor:pointer}.transactions-page .transaction-table select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.transactions-page .loading{display:flex;justify-content:center;align-items:center;padding:4rem 2rem;color:var(--text-muted);font-size:1rem;background-color:var(--bg-primary)}.transactions-page .no-data{display:flex;justify-content:center;align-items:center;padding:4rem 2rem;color:var(--text-muted);font-size:1rem;text-align:center;background-color:var(--bg-primary)}.transactions-page .transactions-pagination{padding:.5rem .75rem;border-top:1px solid var(--border-primary);background-color:var(--bg-tertiary)}.transactions-page .pagination-container{flex-direction:row!important;justify-content:space-between!important;align-items:center!important;flex-wrap:wrap;gap:1rem}@media (max-width: 1200px){.transactions-page .filters-row{flex-wrap:wrap}.transactions-page .search-group{flex:1;min-width:200px}.transactions-page .date-group{flex:1;min-width:180px}}@media (max-width: 1024px){.transactions-page .primary-filters{padding:1rem}.transactions-page .filters-row{gap:1rem}.transactions-page .secondary-filters{flex-wrap:wrap}.transactions-page .filter-group{flex:1;min-width:150px}}@media (max-width: 768px){.transactions-page{padding:1rem}.transactions-page .filters-container{gap:1rem}.transactions-page .primary-filters{padding:1rem}.transactions-page .filters-row{flex-direction:column;gap:1rem}.transactions-page .filter-group{min-width:0;width:100%}.transactions-page .amount-range-inputs{flex-direction:column;gap:.5rem;align-items:stretch}.transactions-page .amount-separator{text-align:center;padding:.25rem 0}.transactions-page .checkbox-container{justify-content:center}.transactions-page .transactions-summary{flex-direction:column;align-items:flex-start;gap:.5rem}.transactions-page .pagination-container{flex-direction:column!important;align-items:stretch!important}}@media (max-width: 480px){.transactions-page{padding:.5rem}.transactions-page .transaction-filters-advanced{padding:1rem}.transactions-page .primary-filters{padding:.75rem}.transactions-page .filter-input{padding:.625rem .75rem}.transactions-page .filter-header h3{font-size:1.1rem}}.transactions-page .transaction-category-picker{position:relative;min-width:150px}.transactions-page .transaction-table td .category-selector{width:100%}.transactions-page .transaction-table td .category-selector-input-container{width:100%!important}.transactions-page .category-picker-container{display:flex;align-items:center;min-height:36px}.transactions-page .current-category-tag{display:inline-flex;align-items:center;background:var(--bg-accent);color:var(--text-accent);padding:.25rem .5rem;border-radius:6px;font-size:.75rem;font-weight:500;gap:.25rem;border:1px solid var(--border-secondary);line-height:1;max-width:100%}.transactions-page .category-remove-btn{background:none;border:none;color:var(--text-accent);font-size:1rem;font-weight:700;cursor:pointer;padding:0;margin:0;line-height:.8;width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s;flex-shrink:0}.transactions-page .category-remove-btn:hover{background:var(--bg-tertiary)}.transactions-page .category-picker-input{width:100%;padding:.5rem;border:1px solid var(--border-primary);border-radius:6px;background-color:var(--bg-primary);font-size:.75rem;color:var(--text-primary);transition:border-color .2s,box-shadow .2s}.transactions-page .category-picker-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.transactions-page .category-picker-input::placeholder{color:var(--text-muted)}.transactions-page .category-picker-loading{display:flex;align-items:center;justify-content:center;padding:.5rem;font-size:.75rem;color:var(--text-muted);font-style:italic;background-color:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:6px;min-height:32px}.transactions-page .category-picker-suggestions{position:absolute;top:100%;left:0;right:0;z-index:100;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;margin-top:.25rem;max-height:150px;overflow-y:auto}.transactions-page .category-picker-suggestion{width:100%;text-align:left;padding:.5rem .75rem;border:none;background:none;color:var(--text-primary);font-size:.75rem;cursor:pointer;transition:background-color .2s;border-bottom:1px solid var(--border-secondary)}.transactions-page .category-picker-suggestion:last-child{border-bottom:none}.transactions-page .category-picker-suggestion:hover{background-color:var(--bg-tertiary)}.transactions-page .category-picker-suggestion:focus{outline:none;background-color:var(--bg-accent)}.rs-date-range-input,.rs-input[placeholder="Select date range"],.date-range-picker .rs-date-range-input,.date-range-picker .rs-input,.date-range-picker-input.rs-picker-default,.date-range-picker-input .rs-picker-toggle,.date-range-picker .rs-picker-default,.date-range-picker .rs-picker-toggle{background-color:var(--bg-primary)!important;border:1px solid var(--border-primary)!important;color:var(--text-primary)!important;padding:.75rem!important;border-radius:8px!important;font-size:.875rem!important;transition:border-color .2s,box-shadow .2s!important;width:100%!important;min-height:42px!important}.date-range-picker .rs-picker-default{border:none!important}.date-range-picker{display:flex;align-items:stretch}.date-range-picker .rs-picker-default{min-height:42px!important;display:flex!important;align-items:center!important}.date-range-picker .rs-picker-default{padding:0!important}.rs-input-group.rs-input-group-md>.rs-input-group-addon{height:auto}.rs-date-range-input:hover,.rs-input[placeholder="Select date range"]:hover,.date-range-picker .rs-date-range-input:hover,.date-range-picker .rs-input:hover,.date-range-picker-input .rs-picker-toggle:hover,.date-range-picker .rs-picker-toggle:hover{border-color:var(--border-secondary)!important}.rs-date-range-input:focus,.rs-input[placeholder="Select date range"]:focus,.date-range-picker .rs-date-range-input:focus,.date-range-picker .rs-input:focus,.date-range-picker-input .rs-picker-toggle:focus,.date-range-picker-input .rs-picker-toggle:focus-within,.date-range-picker .rs-picker-toggle:focus,.date-range-picker .rs-picker-toggle:focus-within{outline:none!important;border-color:#3b82f6!important;box-shadow:0 0 0 3px #3b82f61a!important}.date-range-picker-input .rs-picker-toggle-placeholder,.date-range-picker .rs-picker-toggle-placeholder{color:var(--text-muted)!important}.date-range-picker-input .rs-picker-toggle-value,.date-range-picker .rs-picker-toggle-value{color:var(--text-primary)!important}.date-range-picker-input .rs-picker-toggle-caret,.date-range-picker .rs-picker-toggle-caret{color:var(--text-muted)!important}.date-range-picker .rs-input-group-addon,.rs-input-group-addon{background-color:var(--bg-primary)!important;border:1px solid var(--border-primary)!important;border-left:none!important;color:var(--text-muted)!important}.date-range-picker-input .rs-picker-toggle *,.date-range-picker .rs-picker-toggle *,.date-range-picker *{background-color:inherit!important}.custom-date-picker.rs-picker-default,.custom-date-picker .rs-picker-toggle{background-color:var(--bg-primary)!important;border:1px solid var(--border-primary)!important;color:var(--text-primary)!important}.custom-date-picker .rs-picker-toggle-placeholder{color:var(--text-muted)!important}.custom-date-picker .rs-picker-toggle-value{color:var(--text-primary)!important}.custom-date-picker .rs-picker-toggle-caret{color:var(--text-muted)!important}.custom-date-picker[style]{background-color:var(--bg-primary)!important;border-color:var(--border-primary)!important}.custom-date-picker *{background-color:inherit!important;color:inherit!important}.transactions-page .transaction-table .running-balance{text-align:right;font-weight:600;color:var(--text-secondary)}.transactions-page .running-balance-toggle{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary);cursor:pointer}.transactions-page .running-balance-toggle input[type=checkbox]{margin:0}.transactions-page .running-balance-disabled{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-muted)}.transactions-page .info-text{font-style:italic}.transactions-page .transactions-controls{display:flex;align-items:center;gap:1rem}.transactions-page .sortable-header{background:var(--bg-tertiary);padding:12px 16px;text-align:left;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border-primary);white-space:nowrap;-webkit-user-select:none;user-select:none;transition:background-color .2s;cursor:pointer}.transactions-page .sortable-header:hover{background:var(--bg-secondary)}.transactions-page .sortable-header.active{background:var(--bg-accent);color:var(--text-primary)}.transactions-page .header-content{display:flex;align-items:center;justify-content:space-between;gap:8px}.transactions-page .sort-indicator{font-size:.875rem;color:var(--text-muted);font-weight:400;opacity:.6;display:flex;align-items:center;transition:all .2s}.transactions-page .sortable-header:hover .sort-indicator{opacity:.9}.transactions-page .sortable-header.active .sort-indicator{opacity:1;color:var(--text-accent)}.transactions-page .sort-indicator svg{width:16px;height:16px}.transactions-page .transaction-table th{background-color:var(--bg-tertiary);font-weight:600;color:var(--text-secondary);font-size:.6875rem;text-transform:uppercase;letter-spacing:.05em}.transactions-page .transaction-table th.text-right,.transactions-page .transaction-table td.text-right{text-align:right}.transactions-page .transaction-table .sortable-header.text-right .header-content{justify-content:flex-end}.transactions-page .transaction-description{display:flex;flex-direction:column;gap:.25rem}.transactions-page .counterparty-badge{display:inline-flex;align-items:center;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500;line-height:1;max-width:fit-content;border:1px solid}.transactions-page .counterparty-badge.positive{background:#22c55e1a;color:var(--positive-amount);border-color:#22c55e33}.transactions-page .counterparty-badge.negative{background:#ef44441a;color:var(--negative-amount);border-color:#ef444433}.toast-actions{padding:0 16px 12px;display:flex;justify-content:flex-end;gap:8px}.toast-undo,.toast-action{background:#ffffff40;border:none;color:currentColor;cursor:pointer;padding:6px 16px;border-radius:4px;font-size:.75rem;font-weight:700;transition:all .2s;text-transform:uppercase;letter-spacing:.8px}.toast-undo:hover,.toast-action:hover{background:#ffffff59}.transaction-categorizations-page{padding:24px;max-width:1400px;margin:0 auto}.card-label{font-size:.875rem;color:var(--text-muted);font-weight:500}.filters-top{margin-bottom:24px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;box-shadow:0 1px 3px var(--shadow-light)}.categorizations-content{width:100%}.filters-top .transaction-filters-advanced{padding:16px}.filters-top .filters-grid-horizontal{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.filters-top .filter-section{flex:0 0 auto}.filters-top .filter-section-categories{flex:1 1 300px;min-width:200px}.filters-top .clear-all-button{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b;padding:8px 12px;border-radius:4px;font-size:.875rem;cursor:pointer;transition:all .2s;white-space:nowrap}.filters-top .clear-all-button:hover{background:#fecaca;border-color:#f87171}.filters-top .search-input,.filters-top .filter-select{width:100%;padding:8px 12px;border:1px solid var(--border-secondary);border-radius:4px;font-size:.875rem;transition:border-color .2s;background:var(--bg-primary);color:var(--text-primary)}.filters-top .search-input:focus,.filters-top .filter-select:focus{outline:none;border-color:var(--text-accent);box-shadow:0 0 0 3px #2563eb1a}.filters-top .category-tag-input{position:relative}.filters-top .tag-input-container{display:flex;flex-wrap:wrap;gap:6px;padding:8px 12px;border:1px solid var(--border-secondary);border-radius:4px;min-height:40px;background:var(--bg-primary);transition:border-color .2s}.filters-top .tag-input-container:focus-within{border-color:var(--text-accent);box-shadow:0 0 0 3px #2563eb1a}.filters-top .category-tag{display:inline-flex;align-items:center;gap:4px;background:#eff6ff;color:#1e40af;padding:4px 8px;border-radius:4px;font-size:.75rem;font-weight:500}.filters-top .category-tag-remove{background:none;border:none;color:#1e40af;cursor:pointer;padding:0;font-weight:700;line-height:1}.filters-top .category-tag-remove:hover{color:#1d4ed8}.filters-top .category-input{flex:1;min-width:100px;border:none;outline:none;padding:0;font-size:.875rem;background:transparent;color:var(--text-primary)}.filters-top .category-input::placeholder{color:var(--text-muted)}.filters-top .category-suggestions{position:absolute;top:100%;left:0;right:0;background:var(--bg-primary);border:1px solid var(--border-secondary);border-top:none;border-radius:0 0 4px 4px;box-shadow:0 4px 6px var(--shadow-light);z-index:10;max-height:200px;overflow-y:auto}.filters-top .category-suggestion{display:block;width:100%;padding:8px 12px;text-align:left;background:none;border:none;cursor:pointer;font-size:.875rem;transition:background-color .2s;color:var(--text-primary)}.filters-top .category-suggestion:hover{background:var(--bg-tertiary)}.filters-top .category-suggestion:first-child{border-top:1px solid var(--border-primary)}.categorizations-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:16px}.categorizations-summary h2{margin:0 0 4px;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.categorization-count{color:var(--text-muted);font-size:.875rem}.categorizations-actions{display:flex;gap:12px;flex-wrap:wrap}.create-button{background:#059669;border:1px solid #047857;border-radius:6px;padding:8px 12px;font-size:.875rem;cursor:pointer;transition:all .2s;color:#fff;font-weight:500}.create-button:hover{background:#047857;border-color:#065f46}.create-button:disabled{background:#9ca3af;border-color:#6b7280;cursor:not-allowed}.cleanup-button,.refresh-button{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px;padding:8px 12px;font-size:.875rem;cursor:pointer;transition:all .2s;color:var(--text-primary)}.cleanup-button:hover{background:#fee2e2;border-color:#fca5a5}.refresh-button:hover{background:var(--bg-tertiary);border-color:var(--text-accent)}.categorizations-table-container{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;overflow:hidden;box-shadow:0 1px 3px var(--shadow-light)}.categorization-table{width:100%;border-collapse:collapse;background:var(--bg-primary)}.categorization-table th,.categorization-table td{color:var(--text-primary)!important}.categorization-table th{background:var(--bg-tertiary);padding:12px 16px;text-align:left;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border-primary);white-space:nowrap}.sortable-header{background:var(--bg-tertiary);padding:12px 16px;text-align:left;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border-primary);white-space:nowrap;-webkit-user-select:none;user-select:none;transition:background-color .2s}.sortable-header:hover{background:var(--bg-secondary)}.sortable-header.active{background:var(--bg-accent);color:var(--text-primary)}.header-content{display:flex;align-items:center;justify-content:space-between;gap:8px}.sort-indicator{font-size:.875rem;color:var(--text-muted);font-weight:400;opacity:.7}.sortable-header.active .sort-indicator{opacity:1;color:var(--text-accent)}.categorization-table td{padding:12px 16px;border-bottom:1px solid var(--border-primary);vertical-align:middle}.categorization-row{cursor:pointer;transition:background-color .2s}.categorization-row:hover{background:var(--bg-tertiary)}.categorization-row.expanded{background:var(--bg-accent)}.col-description{width:30%;min-width:200px}.col-category{width:35%;min-width:200px}.col-usage{width:12%;min-width:100px}.col-source{width:8%;min-width:80px}.col-created{width:12%;min-width:100px}.col-actions{width:3%;min-width:60px}.description-text{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem;background:var(--bg-tertiary);padding:4px 8px;border-radius:4px;display:inline-block;max-width:100%;word-wrap:break-word;overflow-wrap:break-word;color:var(--text-primary)}.source-badge{display:inline-block;padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:500}.source-badge.manual{background:#dbeafe;color:#1e40af}.source-badge.ai{background:#dcfce7;color:#166534}.usage-indicator{display:inline-block;padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:500}.usage-indicator.high{background:#dcfce7;color:#166534}.usage-indicator.medium{background:#fef3c7;color:#92400e}.usage-indicator.low{background:#fed7aa;color:#c2410c}.usage-indicator.unused{background:#fee2e2;color:#991b1b}.action-button{background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;font-size:1rem;transition:background-color .2s}.action-button:hover{background:var(--bg-tertiary)}.action-button.delete:hover{background:#fee2e2}.expanded-row{background:var(--bg-accent)!important}.expanded-content{padding:16px 0}.expanded-details{display:grid;gap:8px}.detail-row{display:flex;gap:8px;font-size:.875rem}.detail-row strong{min-width:120px;color:var(--text-secondary)}.table-loading,.table-empty{text-align:center;padding:48px 24px;color:var(--text-muted)}.categorizations-pagination{margin-top:24px;display:flex;justify-content:center}.categorizations-pagination-top{margin:16px 0;display:flex;justify-content:center;padding:12px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px}.categorizations-pagination-top .pagination-controls{gap:6px}.categorizations-pagination-top .pagination-button{padding:6px 10px;font-size:.8rem;min-width:36px}@media (max-width: 1024px){.summary-cards{grid-template-columns:repeat(2,1fr)}.filters-top .filters-grid-horizontal{flex-direction:column;align-items:stretch;gap:8px}.filters-top .filter-section-categories{flex:1;min-width:auto}}@media (max-width: 768px){.transaction-categorizations-page{padding:16px}.categorizations-header{flex-direction:column;align-items:stretch}.summary-cards{grid-template-columns:1fr}.categorization-table{font-size:.875rem}.col-created,.col-actions{display:none}.description-text{font-size:.75rem}}.form-help-text{font-size:.75rem;color:var(--text-muted);margin-top:4px;font-style:italic;line-height:1.3}.form-group .category-selector{border:none!important;padding:0!important;background:transparent!important}.checkbox-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:.875rem;color:var(--text-primary)}.checkbox-label input[type=checkbox]{width:auto!important;margin:2px 0 0;flex-shrink:0}.checkbox-label input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}.checkbox-label:has(input:disabled){cursor:not-allowed}.checkbox-content{flex:1;display:flex;flex-direction:column;gap:4px}.checkbox-text{font-weight:500;color:var(--text-primary)}.checkbox-description{font-size:.75rem;color:var(--text-muted);font-style:italic;line-height:1.3}.selected-category{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;min-height:40px;box-sizing:border-box}.selected-category-text{flex:1;font-size:.875rem;color:var(--text-primary)}.category-clear-button{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:0;margin-left:8px;font-size:1.2rem;line-height:1;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:3px;transition:all .2s}.category-clear-button:hover{background:var(--bg-tertiary);color:var(--text-primary)}.category-change-indicator{margin-left:8px;color:var(--text-muted);font-size:.75rem;-webkit-user-select:none;user-select:none}.category-input{width:100%;padding:10px 12px;border:none;outline:none;font-size:.875rem;background:transparent;color:var(--text-primary);box-sizing:border-box}.category-input::placeholder{color:var(--text-muted)}.category-suggestions{position:absolute;top:100%;left:0;right:0;background:var(--bg-primary);border:1px solid var(--border-secondary);border-top:none;border-radius:0 0 6px 6px;box-shadow:0 4px 6px var(--shadow-light);z-index:10;max-height:200px;overflow-y:auto}.category-suggestion{display:block;width:100%;padding:10px 12px;text-align:left;background:none;border:none;cursor:pointer;font-size:.875rem;transition:background-color .2s;color:var(--text-primary);box-sizing:border-box}.category-suggestion:hover{background:var(--bg-tertiary)}.no-suggestions{padding:10px 12px;font-size:.875rem;color:var(--text-muted);text-align:center}.enhancement-rules-page .transactions-pagination{padding:1.5rem 2rem;border-top:1px solid var(--border-primary);background-color:var(--bg-tertiary)}.enhancement-rules-page .pagination-container{flex-direction:row!important;justify-content:space-between!important;align-items:center!important;flex-wrap:wrap;gap:1rem}@media (max-width: 768px){.enhancement-rules-page .pagination-container{flex-direction:column!important;align-items:stretch!important}}.categories-page{padding:24px;max-width:1400px;margin:0 auto}.summary-card{background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-elevated) 100%);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:1.5rem;text-align:center;box-shadow:var(--shadow-md);transition:all var(--transition-base);position:relative;overflow:hidden}.summary-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent-blue) 0%,var(--accent-purple) 100%)}.summary-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.card-value{font-size:2.25rem;font-weight:700;background:linear-gradient(135deg,var(--accent-blue) 0%,var(--accent-purple) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.card-label{font-size:.875rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.error-message{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b;padding:12px 16px;border-radius:6px;margin-bottom:24px}.filters-top{margin-bottom:24px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;box-shadow:0 1px 3px var(--shadow-light);padding:16px}.filter-section{display:flex;gap:16px;align-items:center;justify-content:space-between;flex-wrap:wrap}.search-container{flex:1;min-width:250px}.search-input{width:100%;padding:10px 12px;border:1px solid var(--border-secondary);border-radius:6px;font-size:.875rem;background:var(--bg-primary);color:var(--text-primary);transition:border-color .2s;box-sizing:border-box}.search-input:focus{outline:none;border-color:var(--text-accent);box-shadow:0 0 0 3px #2563eb1a}.action-buttons{display:flex;gap:12px;flex-wrap:wrap}.categories-content{width:100%}.categories-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.categories-header h2{margin:0 0 .25rem;font-size:1.5rem;font-weight:600;color:var(--text-primary);background:linear-gradient(135deg,var(--text-primary) 0%,var(--text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.category-count{color:var(--text-muted);font-size:.875rem;font-weight:500}.categories-tree-container{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-md);transition:all var(--transition-base)}.categories-tree-container:hover{box-shadow:var(--shadow-lg)}.category-tree{padding:16px}.category-tree-controls{display:flex;justify-content:space-between;align-items:center;padding:12px 0;margin-bottom:16px;border-bottom:1px solid var(--border-primary)}.expand-collapse-controls{display:flex;gap:8px}.control-button{background:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:6px;padding:8px 14px;font-size:.8125rem;cursor:pointer;transition:all .2s;color:var(--text-primary);font-weight:500;display:inline-flex;align-items:center;gap:4px}.control-button:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-accent);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.control-button:disabled{opacity:.5;cursor:not-allowed;background:var(--bg-secondary);border-color:var(--border-secondary);transform:none}.expand-status{font-size:.75rem;color:var(--text-muted);font-weight:500}.category-tree-node{margin-bottom:8px}.category-tree-node:last-child{margin-bottom:0}.category-row{display:flex;align-items:center;justify-content:space-between;padding:12px 8px;border-radius:6px;transition:background-color .2s;min-height:48px}.category-row:hover{background:var(--bg-tertiary)}.category-info{display:flex;align-items:center;gap:12px;flex:1}.category-expand{width:24px;display:flex;align-items:center;justify-content:center}.expand-spacer{color:transparent;font-size:.75rem;opacity:0}.category-name{font-size:1rem;font-weight:500;color:var(--text-primary);flex:1;line-height:20px}.category-stats{margin-left:auto;margin-right:16px}.subcategory-count{font-size:.75rem;color:var(--text-muted);background:var(--bg-secondary);padding:2px 6px;border-radius:12px}.category-actions{display:flex;gap:2px;opacity:0;transition:opacity .2s}.category-row:hover .category-actions{opacity:1}.category-children{margin-left:20px;border-left:2px solid var(--border-primary);padding-left:16px;margin-top:8px}.category-tree-loading,.category-tree-empty{text-align:center;padding:48px 24px;color:var(--text-muted)}.loading-spinner{width:32px;height:32px;border:3px solid #f3f4f6;border-top:3px solid #2563eb;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.button-primary,.button-secondary{padding:10px 20px;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid}.button-primary{background:#2563eb;border-color:#2563eb;color:#fff}.button-primary:hover:not(:disabled){background:#1d4ed8;border-color:#1d4ed8}.button-primary:disabled{background:#9ca3af;border-color:#9ca3af;cursor:not-allowed;opacity:.6}.button-secondary{background:var(--bg-primary);border-color:var(--border-secondary);color:var(--text-primary)}.button-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--text-accent)}.button-secondary:disabled{opacity:.6;cursor:not-allowed}.button-danger{background:#dc2626;border-color:#dc2626;color:#fff;padding:10px 20px;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid}.button-danger:hover:not(:disabled){background:#b91c1c;border-color:#b91c1c}.button-danger:disabled{background:#9ca3af;border-color:#9ca3af;cursor:not-allowed;opacity:.6}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:var(--bg-primary);border-radius:8px;box-shadow:0 10px 25px #00000026;max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 16px;border-bottom:1px solid var(--border-primary)}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-muted);padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-body{padding:20px 24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:var(--text-primary);font-size:.875rem}.form-group input:not(.category-input),.form-group select{width:100%;padding:10px 12px;border:1px solid var(--border-secondary);border-radius:6px;font-size:.875rem;background:var(--bg-primary);color:var(--text-primary);transition:border-color .2s;box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--text-accent);box-shadow:0 0 0 3px #2563eb1a}.form-help-text{font-size:.75rem;color:var(--text-muted);margin-top:4px;font-style:italic}.category-info{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px;padding:12px}.category-info strong{color:var(--text-primary);font-size:.875rem}.category-path{font-size:.875rem;color:var(--text-muted);margin-top:4px;font-family:Monaco,Menlo,Ubuntu Mono,monospace}.modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:16px 24px 20px;border-top:1px solid var(--border-primary)}.toast{position:fixed;top:80px;right:20px;z-index:1300;max-width:400px;min-width:300px;border-radius:8px;box-shadow:0 4px 12px #00000026;animation:slideInRight .3s ease-out;overflow:hidden}.toast-success{background:#10b981;color:#fff}.toast-error{background:#ef4444;color:#fff}.toast-info{background:#3b82f6;color:#fff}.toast-header{display:flex;align-items:center;gap:12px;padding:12px 16px}.toast-icon{font-weight:700;font-size:1rem;flex-shrink:0}.toast-message{flex:1;font-size:.875rem;line-height:1.4}.toast-actions{padding:0 16px 12px;display:flex;justify-content:flex-end}.toast-undo{background:#ffffff40;border:none;color:currentColor;cursor:pointer;padding:6px 16px;border-radius:4px;font-size:.75rem;font-weight:700;transition:all .2s;text-transform:uppercase;letter-spacing:.8px}.toast-undo:hover{background:#ffffff59}.toast-close{background:none;border:none;color:currentColor;cursor:pointer;padding:4px;font-size:1.25rem;line-height:1;opacity:.8;transition:opacity .2s;flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px}.toast-close:hover{opacity:1;background:#ffffff26}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 1024px){.summary-cards{grid-template-columns:repeat(2,1fr)}.filter-section{flex-direction:column;align-items:stretch;gap:12px}.search-container{min-width:auto}}@media (max-width: 768px){.categories-page{padding:16px}.categories-header{flex-direction:column;align-items:stretch}.summary-cards{grid-template-columns:1fr}.category-row{padding:8px;min-height:44px}.category-name{font-size:.875rem}.action-buttons{justify-content:center}.category-children{margin-left:12px;padding-left:12px}.category-tree-controls{flex-direction:column;align-items:stretch;gap:8px}.expand-collapse-controls{justify-content:center}.expand-status{text-align:center}}.accounts-page{padding:24px;max-width:1400px;margin:0 auto}.page-header{margin-bottom:32px}.page-header h1{margin:0 0 8px;font-size:2rem;font-weight:600;color:#1a1a1a}.page-description{margin:0;color:#666;font-size:1rem}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px}.summary-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;padding:20px;text-align:center;box-shadow:0 1px 3px var(--shadow-light)}.card-value{font-size:2rem;font-weight:700;color:#2563eb;margin-bottom:4px}.card-label{font-size:.875rem;color:#666;font-weight:500}.error-message{background:#fee2e2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:6px;margin-bottom:24px}.filters-top{margin-bottom:24px}.filter-section{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}.search-container{flex:1;min-width:300px}.search-input{width:100%;padding:12px 16px;border:1px solid var(--border-primary);border-radius:6px;font-size:1rem;transition:border-color .2s ease}.search-input:hover{border-color:var(--border-secondary)}.search-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1a}.action-buttons{display:flex;gap:8px}.button-primary,.button-secondary,.button-danger{padding:10px 16px;border-radius:6px;border:none;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.button-primary{background:#2563eb;color:#fff}.button-primary:hover:not(:disabled){background:#1d4ed8}.button-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-primary)}.button-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-secondary)}.button-danger{background:#dc2626;color:#fff}.button-danger:hover:not(:disabled){background:#b91c1c}.button-primary:disabled,.button-secondary:disabled,.button-danger:disabled{opacity:.5;cursor:not-allowed}.accounts-content{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;overflow:hidden}.accounts-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-primary);background:var(--bg-secondary)}.accounts-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.account-count{font-size:.875rem;color:#666;font-weight:500}.accounts-table-container{min-height:400px}.loading-message,.empty-message{display:flex;align-items:center;justify-content:center;height:400px;color:#666;font-size:1rem}.accounts-table{width:100%;border-collapse:collapse}.accounts-table th{background:var(--bg-secondary);padding:16px 24px;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:1px solid var(--border-primary)}.accounts-table td{padding:16px 24px;border-bottom:1px solid var(--border-primary);vertical-align:middle}.accounts-table tbody tr:hover{background:var(--bg-secondary)}.account-actions{display:flex;gap:4px;justify-content:center;align-items:center}.initial-balance-header{text-align:right;width:250px}.initial-balance-cell{text-align:right;font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-size:.875rem;color:var(--text-secondary);cursor:pointer;transition:background-color .15s ease,color .15s ease;border-radius:4px}.initial-balance-cell:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}@media (max-width: 768px){.accounts-page{padding:16px}.filter-section{flex-direction:column;align-items:stretch}.search-container{min-width:auto}.action-buttons{justify-content:center}.accounts-header{flex-direction:column;align-items:flex-start;gap:8px}.accounts-table{font-size:.875rem}.accounts-table th,.accounts-table td{padding:12px 16px}.account-actions{flex-direction:column;gap:4px}.initial-balance-header{width:auto}.initial-balance-cell{font-size:.75rem}}.charts-page{padding:1.5rem;min-height:100vh;background-color:var(--bg-secondary)}.page-header{margin-bottom:2rem}.page-header h1{font-size:2rem;font-weight:700;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent-purple) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .5rem;letter-spacing:-.02em}.page-description{color:var(--text-muted);margin:0;font-size:.95rem}.filters-section{background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-elevated) 100%);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);margin-bottom:2rem;border:1px solid var(--border-primary);transition:all var(--transition-base)}.filters-section:hover{box-shadow:var(--shadow-lg)}.charts-layout{display:flex;flex-direction:column;gap:2rem}.charts-content{flex:1;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-elevated) 100%);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:2rem;border:1px solid var(--border-primary);transition:all var(--transition-base);position:relative;overflow:hidden}.charts-content:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent-blue) 0%,var(--accent-purple) 50%,var(--accent-pink) 100%)}.charts-content:hover{box-shadow:var(--shadow-lg)}.charts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border-primary)}.charts-controls{display:flex;align-items:center;gap:1rem;margin-left:auto}.view-mode-toggle{display:inline-flex;gap:.25rem;background:transparent;padding:0;border-radius:0;order:3;margin-left:auto}.category-selector{display:flex;align-items:center;order:2}.period-toggle{display:inline-flex;gap:.25rem;background:transparent;padding:0;border-radius:0;order:1}.view-mode-toggle button{background:transparent;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text-secondary);transition:all .15s ease;width:100px;text-align:center}.period-toggle button{background:transparent;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text-secondary);transition:all .15s ease;width:80px;text-align:center}.view-mode-toggle button:hover,.period-toggle button:hover{color:var(--text-primary);background:#ffffff0d}.view-mode-toggle button.active,.period-toggle button.active{background:var(--button-primary);color:#fff}.view-mode-toggle button.active:hover,.period-toggle button.active:hover{background:var(--button-primary-hover)}.active-toggle{display:flex;align-items:center;order:1}.active-toggle .toggle-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text-secondary)}.active-toggle .toggle-label input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--button-primary)}.active-toggle .toggle-label:hover{color:var(--text-primary)}.category-selector{display:flex;align-items:center}.transaction-type-filter{display:flex;align-items:center;gap:.5rem}.transaction-type-filter label{color:var(--text-primary);font-weight:500;font-size:.9rem}.transaction-type-select{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:.5rem .75rem;color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;min-width:200px}.transaction-type-select:focus{outline:none;border-color:var(--button-primary);box-shadow:0 0 0 2px #3b82f633}.transaction-type-select:hover{background:#ffffff14;border-color:#ffffff26}.charts-summary h2{margin:0 0 .5rem;color:var(--text-primary);font-size:1.5rem}.chart-stats{display:flex;gap:2rem;margin-top:.5rem}.stat{color:var(--text-muted);font-size:.9rem}.back-button{background:var(--button-primary);color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.back-button:hover{background:var(--button-primary-hover)}.chart-container{margin:2rem 0;min-height:500px;display:flex;align-items:center;justify-content:center;position:relative;padding:2rem;background:linear-gradient(135deg,transparent 0%,rgba(59,130,246,.02) 100%);border-radius:var(--radius-lg)}.loading-indicator{text-align:center;color:var(--text-muted);font-size:1rem;padding:3rem;font-weight:500}.no-data-message{text-align:center;color:var(--text-muted);font-size:1rem;padding:3rem;background:var(--bg-tertiary);border-radius:var(--radius-lg);border:2px dashed var(--border-primary);max-width:500px;margin:0 auto}.chart-help{background:linear-gradient(135deg,var(--bg-accent) 0%,rgba(59,130,246,.05) 100%);border:1px solid rgba(59,130,246,.2);border-radius:var(--radius-lg);padding:1.25rem;margin-top:1.5rem;text-align:center;box-shadow:var(--shadow-sm)}.chart-help p{margin:0;color:var(--text-accent);font-size:.875rem;font-weight:500}.error-message{background:#fee2e2;border:1px solid #fca5a5;color:#dc2626;padding:1rem;border-radius:4px;margin-bottom:1rem}.charts-page .recharts-tooltip-wrapper{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;box-shadow:0 4px 6px var(--shadow-light)}.charts-page .recharts-default-tooltip{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;color:var(--text-primary)}.charts-page .recharts-tooltip-label{color:var(--text-primary)}.charts-page .recharts-tooltip-item{color:var(--text-secondary)}.charts-page .recharts-legend-wrapper,.charts-page .recharts-legend-item,.charts-page .recharts-legend-item-text{color:var(--text-primary)}.charts-page .recharts-surface{background:transparent}.chart-container text{font-family:inherit;pointer-events:none}.chart-container .recharts-pie-label-text{font-size:12px;font-weight:500;fill:var(--text-primary)}@media (max-width: 1200px){.charts-layout{flex-direction:column}.filters-sidebar{flex:none;position:static;max-height:none;width:100%}.charts-content{width:100%}}@media (max-width: 768px){.charts-page{padding:1rem}.charts-header{flex-direction:column;align-items:flex-start;gap:1rem}.charts-controls{flex-direction:column;align-items:flex-start;gap:.5rem;width:100%}.transaction-type-filter{flex-direction:column;align-items:flex-start;gap:.25rem;width:100%}.transaction-type-select{width:100%}.chart-stats,.date-range-inputs{flex-direction:column;gap:.5rem}.date-shortcuts{justify-content:center}}.recurring-expenses-page{padding:1.5rem;min-height:100vh;background-color:var(--bg-secondary)}.recurring-expenses-page .page-header{margin-bottom:2rem}.recurring-expenses-page .header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.recurring-expenses-page .page-header h1{font-size:2rem;font-weight:700;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent-purple) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .5rem;letter-spacing:-.02em}.recurring-expenses-page .page-description{color:var(--text-muted);margin:0;font-size:.95rem}.recurring-expenses-page .header-controls{display:flex;align-items:center;gap:1rem}.recurring-expenses-page .tabs-container{display:flex;gap:.5rem;margin-bottom:1.5rem}.recurring-expenses-page .tab-button{padding:.75rem 1.5rem;border:1px solid var(--border-primary);background:var(--bg-primary);color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;border-radius:8px;transition:all .2s}.recurring-expenses-page .tab-button:hover{color:var(--text-primary);border-color:var(--button-primary)}.recurring-expenses-page .tab-button.active{background:var(--button-primary);color:#fff;border-color:var(--button-primary)}.recurring-expenses-page .toggle-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text-secondary);background:var(--bg-primary);padding:.5rem 1rem;border-radius:8px;border:1px solid var(--border-primary)}.recurring-expenses-page .toggle-label input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--button-primary)}.recurring-expenses-page .toggle-label:hover{color:var(--text-primary);border-color:var(--button-primary)}.recurring-expenses-page .page-content{background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-elevated) 100%);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:2rem;border:1px solid var(--border-primary);position:relative;overflow:hidden}.recurring-expenses-page .page-content:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent-blue) 0%,var(--accent-purple) 50%,var(--accent-pink) 100%)}.recurring-expenses-page .loading-indicator{text-align:center;color:var(--text-muted);font-size:1rem;padding:3rem;font-weight:500}.recurring-expenses-page .no-data-message{text-align:center;color:var(--text-muted);font-size:1rem;padding:3rem;background:var(--bg-tertiary);border-radius:var(--radius-lg);border:2px dashed var(--border-primary)}.recurring-expenses-page .error-message{background:#fee2e2;border:1px solid #fca5a5;color:#dc2626;padding:1rem;border-radius:4px;margin-bottom:1rem}@media (max-width: 768px){.recurring-expenses-page{padding:1rem}.recurring-expenses-page .header-content{flex-direction:column;gap:1rem}.recurring-expenses-page .header-controls{width:100%}}.statements-page{padding:2rem;max-width:1200px;margin:0 auto}.statements-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.statements-header h1{margin:0;font-size:2rem;color:var(--text-primary)}.statements-count{color:var(--text-muted);font-size:.9rem;margin:0}.loading{text-align:center;padding:3rem;color:var(--text-muted);font-size:1.1rem}.error-message{text-align:center;padding:3rem;color:#d32f2f;font-size:1.1rem;background-color:#ffebee;border-radius:8px;border:1px solid #ffcdd2}.empty-state{text-align:center;padding:4rem 2rem;color:#666;font-size:1.1rem;background-color:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.statements-table-container{background:var(--bg-primary);border-radius:8px;box-shadow:0 2px 4px var(--shadow-light);overflow:hidden}.statements-table{width:100%;border-collapse:collapse}.statements-table th,.statements-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border-primary)}.statements-table td:nth-child(4){text-align:right}.statements-table th{background-color:var(--bg-secondary);font-weight:600;color:var(--text-secondary);font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.statements-table th.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.statements-table th.sortable-header:hover{background-color:var(--bg-tertiary)}.statements-table th.sortable-header .header-content{display:flex;align-items:center;gap:4px}.statements-table th.sortable-header .sort-indicator{display:flex;align-items:center;color:var(--text-muted);opacity:.5}.statements-table th.sortable-header.active .sort-indicator{opacity:1;color:var(--button-primary)}.statements-table tbody tr:hover{background-color:var(--bg-secondary)}.statements-table tbody tr:last-child td{border-bottom:none}.filename-cell{display:flex;align-items:center}.filename{font-weight:500;color:var(--text-primary);word-break:break-all;max-width:200px}.account-name{font-weight:500;color:var(--text-primary)}.file-type-badge{display:inline-block;padding:.25rem .5rem;background-color:#e3f2fd;color:#1976d2;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.transaction-count{font-weight:600;color:#2e7d32;text-align:right}.date-range{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-muted)}.date-separator{color:var(--text-muted);font-weight:300}.upload-date{font-size:.9rem;color:var(--text-muted)}.actions{display:flex;justify-content:center;align-items:center}@media (max-width: 768px){.statements-page{padding:1rem}.statements-header{flex-direction:column;align-items:flex-start;gap:.5rem}.statements-table-container{overflow-x:auto}.statements-table{min-width:700px}.statements-table th,.statements-table td{padding:.75rem .5rem}.filename{max-width:150px}}.settings-page{padding:24px;max-width:800px;margin:0 auto}.settings-page .page-header{margin-bottom:32px}.settings-page .page-header h1{margin:0 0 8px;font-size:2rem;font-weight:600;color:var(--text-primary)}.settings-page .page-description{margin:0;color:var(--text-muted);font-size:1rem}.settings-sections{display:flex;flex-direction:column;gap:24px}.settings-card{background:var(--bg-primary)!important;border:1px solid var(--border-primary)!important;border-radius:var(--radius-lg)!important;box-shadow:var(--shadow-sm)!important}.settings-card .MuiCardContent-root{padding:24px!important}.settings-card .MuiTypography-h6{color:var(--text-primary);font-weight:600}.theme-toggle-group{display:flex;gap:8px}.theme-toggle-group .MuiToggleButton-root{flex:1;padding:12px 16px;border:1px solid var(--border-primary)!important;border-radius:var(--radius-md)!important;color:var(--text-secondary);text-transform:none;font-weight:500}.theme-toggle-group .MuiToggleButton-root.Mui-selected{background:var(--bg-accent)!important;color:var(--text-accent)!important;border-color:var(--border-accent)!important}.theme-toggle-group .MuiToggleButton-root:hover{background:var(--bg-hover)}@media (max-width: 600px){.settings-page{padding:16px}.theme-toggle-group{flex-direction:column}.theme-toggle-group .MuiToggleButton-root{justify-content:center}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);padding:1rem}.login-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:3rem;max-width:400px;width:100%;text-align:center}.login-icon{width:100px;height:100px;margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-blue) 0%,var(--accent-purple) 100%);border-radius:var(--radius-xl);color:#fff}.login-title{color:var(--text-primary);font-weight:700;margin-bottom:.5rem}.login-subtitle{color:var(--text-muted);margin-bottom:0}.google-button{background:var(--bg-primary)!important;color:var(--text-primary)!important;border:1px solid var(--border-secondary)!important;text-transform:none!important;font-size:1rem!important;font-weight:500!important;padding:.875rem 1.5rem!important;border-radius:var(--radius-md)!important;transition:all var(--transition-base)!important;margin-top:2rem!important}.google-button:hover{background:var(--bg-hover)!important;border-color:var(--border-accent)!important;box-shadow:var(--shadow-md)!important}.google-button .MuiButton-startIcon{color:#4285f4}@media (max-width: 480px){.login-card{padding:2rem 1.5rem}.login-icon{width:64px;height:64px}.login-icon svg{font-size:36px!important}}.app{max-width:1400px;margin:0 auto;padding:1.5rem;font-family:inherit}.transactions-page h1{text-align:center;margin-bottom:2rem;color:var(--text-primary);background:linear-gradient(135deg,var(--text-primary) 0%,var(--text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.error-message{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b;padding:1rem 1.25rem;margin-bottom:1rem;border-radius:var(--radius-lg);border:1px solid #fca5a5;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:.75rem;font-weight:500}.transactions-container{display:grid;grid-template-columns:1fr 2fr;gap:2rem}@media (max-width: 768px){.transactions-container{grid-template-columns:1fr}}.transaction-form{background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-tertiary) 100%);padding:1.75rem;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);border:1px solid var(--border-primary);transition:all var(--transition-base)}.transaction-form:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.transaction-form h2{margin-top:0;margin-bottom:1.5rem;color:var(--text-primary);font-weight:600;font-size:1.25rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-secondary);font-size:.875rem;letter-spacing:.025em}.form-group input{width:100%;padding:.625rem .875rem;border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:.875rem;background-color:var(--bg-primary);color:var(--text-primary);transition:all var(--transition-base)}.form-group input:focus{border-color:var(--border-accent);box-shadow:0 0 0 3px #3b82f61a;outline:none}button{background-color:var(--button-primary);color:var(--bg-primary);border:none;padding:.75rem 1rem;border-radius:4px;cursor:pointer;font-size:1rem;width:100%;margin-top:1rem;transition:background-color .2s}button:hover{background-color:var(--button-primary-hover)}button:disabled{background-color:var(--button-secondary);cursor:not-allowed}.transaction-table{background-color:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:0;border:1px solid var(--border-primary);overflow:visible;transition:all var(--transition-base)}.transaction-table:hover{box-shadow:var(--shadow-lg)}.transaction-table h2{margin:0;padding:1.25rem 1.5rem;color:var(--text-primary);font-weight:600;font-size:1.25rem;background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%);border-bottom:1px solid var(--border-primary)}table{width:100%;border-collapse:collapse}th,td{padding:1rem 1.25rem;text-align:left;border-bottom:1px solid var(--border-primary);color:var(--text-primary);transition:background-color var(--transition-fast)}th{background:linear-gradient(180deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:2px solid var(--border-secondary)}tr{transition:all var(--transition-fast)}th.text-right,td.text-right,th.amount-column,td.amount-column,.sortable-header.text-right{text-align:right!important}.loading,.no-data{text-align:center;padding:2rem;color:var(--text-muted)}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,SF Pro Display,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;font-weight:400;color-scheme:light dark;--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--bg-accent: #eff6ff;--bg-hover: #f9fafb;--bg-elevated: #ffffff;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #64748b;--text-accent: #2563eb;--text-on-accent: #ffffff;--border-primary: #e2e8f0;--border-secondary: #cbd5e1;--border-accent: #3b82f6;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px -1px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--button-primary: #3b82f6;--button-primary-hover: #2563eb;--button-primary-active: #1d4ed8;--button-secondary: #64748b;--button-secondary-hover: #475569;--button-danger: #ef4444;--button-danger-hover: #dc2626;--button-success: #10b981;--button-success-hover: #059669;--positive-amount: #059669;--positive-amount-bg: #d1fae5;--negative-amount: #dc2626;--negative-amount-bg: #fee2e2;--accent-blue: #3b82f6;--accent-purple: #8b5cf6;--accent-green: #10b981;--accent-orange: #f59e0b;--accent-pink: #ec4899;--icon-primary: #3b82f6;--icon-success: #10b981;--icon-error: #dc2626;--icon-muted: #64748b;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}@media (prefers-color-scheme: dark){:root{--bg-primary: #1e293b;--bg-secondary: #0f172a;--bg-tertiary: #334155;--bg-accent: #1e3a8a;--bg-hover: #293548;--bg-elevated: #243248;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--text-accent: #60a5fa;--text-on-accent: #ffffff;--border-primary: #334155;--border-secondary: #475569;--border-accent: #3b82f6;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .4), 0 1px 2px -1px rgba(0, 0, 0, .4);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -2px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -4px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .6), 0 8px 10px -6px rgba(0, 0, 0, .6);--button-primary: #3b82f6;--button-primary-hover: #60a5fa;--button-primary-active: #2563eb;--button-secondary: #64748b;--button-secondary-hover: #94a3b8;--button-danger: #ef4444;--button-danger-hover: #f87171;--button-success: #10b981;--button-success-hover: #34d399;--positive-amount: #34d399;--positive-amount-bg: #064e3b;--negative-amount: #f87171;--negative-amount-bg: #7f1d1d;--accent-blue: #60a5fa;--accent-purple: #a78bfa;--accent-green: #34d399;--accent-orange: #fbbf24;--accent-pink: #f472b6;--icon-primary: #60a5fa;--icon-success: #34d399;--icon-error: #f87171;--icon-muted: #94a3b8}}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--bg-secondary);color:var(--text-primary);transition:background-color var(--transition-slow),color var(--transition-slow)}button{background-color:var(--button-primary);color:var(--text-on-accent);border:none;padding:.625rem 1.25rem;border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;font-weight:500;transition:all var(--transition-base);box-shadow:var(--shadow-sm);letter-spacing:.025em;position:relative;overflow:hidden}button:hover{background-color:var(--button-primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}button:active{background-color:var(--button-primary-active);transform:translateY(0);box-shadow:var(--shadow-xs)}button:disabled{background-color:var(--button-secondary);cursor:not-allowed;opacity:.6;transform:none;box-shadow:none}button:focus-visible{outline:2px solid var(--border-accent);outline-offset:2px}.positive{color:var(--positive-amount);font-weight:600}.negative{color:var(--negative-amount);font-weight:600}th,td{color:var(--text-primary);border-bottom:1px solid var(--border-primary);padding:.875rem 1rem;transition:background-color var(--transition-fast)}th{background-color:var(--bg-tertiary);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}tr{transition:background-color var(--transition-fast)}tr:hover{background-color:var(--bg-hover)}h1{font-size:2rem;line-height:1.2;font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}h2{font-size:1.5rem;line-height:1.3;font-weight:600;letter-spacing:-.01em;color:var(--text-primary)}h3{font-size:1.25rem;line-height:1.4;font-weight:600;color:var(--text-primary)}input,textarea,select{font-family:inherit;font-size:.875rem;padding:.625rem .875rem;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);transition:all var(--transition-base)}input:hover,textarea:hover,select:hover{border-color:var(--border-secondary)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--border-accent);box-shadow:0 0 0 3px #3b82f61a}input:disabled,textarea:disabled,select:disabled{opacity:.6;cursor:not-allowed;background-color:var(--bg-tertiary)}.button-primary{background-color:var(--button-primary);color:var(--text-on-accent)}.button-primary:hover:not(:disabled){background-color:var(--button-primary-hover)}.button-secondary{background-color:transparent;color:var(--text-primary);border:1px solid var(--border-primary);box-shadow:var(--shadow-xs)}.button-secondary:hover:not(:disabled){background-color:var(--bg-hover);border-color:var(--border-secondary)}.button-outline{background-color:transparent;color:var(--button-primary);border:1px solid var(--button-primary);box-shadow:none}.button-outline:hover:not(:disabled){background-color:var(--bg-accent);border-color:var(--button-primary-hover)}.button-danger{background-color:var(--button-danger);color:var(--text-on-accent)}.button-danger:hover:not(:disabled){background-color:var(--button-danger-hover)}.button-success{background-color:var(--button-success);color:var(--text-on-accent)}.button-success:hover:not(:disabled){background-color:var(--button-success-hover)}.button-ghost{background-color:transparent;color:var(--text-secondary);box-shadow:none}.button-ghost:hover:not(:disabled){background-color:var(--bg-hover);color:var(--text-primary)}.button-sm{padding:.375rem .75rem;font-size:.8125rem}.button-lg{padding:.875rem 1.75rem;font-size:1rem}.card{background-color:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-base);overflow:hidden}.card:hover,.card-elevated{box-shadow:var(--shadow-md)}.card-elevated:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border-primary);background-color:var(--bg-tertiary)}.card-body{padding:1.25rem}.card-footer{padding:1rem 1.25rem;border-top:1px solid var(--border-primary);background-color:var(--bg-tertiary)}.table-modern{width:100%;border-collapse:separate;border-spacing:0;background-color:var(--bg-primary)}.table-modern thead{background:linear-gradient(180deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%)}.table-modern th{padding:1rem;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:2px solid var(--border-secondary)}.table-modern td{padding:.875rem 1rem;border-bottom:1px solid var(--border-primary)}.table-modern tbody tr{transition:all var(--transition-fast)}.table-modern tbody tr:hover{background-color:var(--bg-hover);box-shadow:var(--shadow-xs)}.badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:500;line-height:1}.badge-primary{background-color:var(--bg-accent);color:var(--text-accent);border:1px solid var(--border-accent)}.badge-success{background-color:var(--positive-amount-bg);color:var(--positive-amount);border:1px solid var(--positive-amount)}.badge-danger{background-color:var(--negative-amount-bg);color:var(--negative-amount);border:1px solid var(--negative-amount)}.badge-secondary{background-color:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-primary)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{to{transform:rotate(360deg)}}.loading-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.loading-spin{animation:spin 1s linear infinite}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-lg{font-size:1.125rem}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.MuiButtonBase-root{width:auto!important}.MuiIconButton-root{transition:all .2s ease!important}.MuiIconButton-root:hover{background-color:var(--bg-hover)!important}.MuiIconButton-colorPrimary{color:var(--icon-primary)!important}.MuiIconButton-colorPrimary:hover{background-color:#3b82f614!important}.MuiIconButton-colorError{color:var(--icon-error)!important}.MuiIconButton-colorError:hover{background-color:#ef444414!important}.MuiIconButton-colorSuccess{color:var(--icon-success)!important}.MuiIconButton-colorSuccess:hover{background-color:#10b98114!important}.MuiIconButton-root.Mui-disabled{opacity:.4!important;color:var(--icon-muted)!important}.MuiSvgIcon-fontSizeSmall{font-size:1.25rem!important}.MuiSvgIcon-fontSizeMedium{font-size:1.5rem!important}.MuiSvgIcon-fontSizeLarge{font-size:2rem!important}
