@import "https://fonts.googleapis.com/css2?family=Orbitron:wght@400;500;600;700&family=Exo+2:wght@300;400;500;600;700&family=Inter:wght@300;400;500;600;700&family=Roboto+Mono:wght@300;400;500;600;700&family=Fira+Code:wght@300;400;500;600;700&display=swap";
:root{--color-primary:#0070f3;--color-primary-dark:#005bb5;--color-primary-light:#3291ff;--color-secondary:#7048e8;--color-secondary-dark:#5028c8;--color-success:#38a169;--color-success-light:#c6f6d5;--color-warning:#ff9800;--color-warning-light:#fff3cd;--color-error:#e53e3e;--color-error-light:#fed7d7;--color-info:#3182ce;--color-info-light:#ebf8ff;--color-background:#f5f5f5;--color-white:#fff;--color-content-background:#fff;--color-gray-100:#f9fafb;--color-gray-200:#f1f5f9;--color-gray-300:#e2e8f0;--color-gray-400:#cbd5e0;--color-gray-500:#a0aec0;--color-gray-600:#718096;--color-gray-700:#4a5568;--color-gray-800:#2d3748;--color-gray-900:#1a202c;--color-text:var(--color-gray-800);--color-border:var(--color-gray-300);--color-input-border:var(--color-gray-400);--color-input-focus:var(--color-primary);--color-expense:#d32f2f;--color-income:#197837;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 2px 4px #0000001a;--shadow-lg:0 4px 6px #0000001a;--shadow-xl:0 10px 15px #0000001a;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-md:1rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--font-family-heading:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-family-body:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-family-mono:"SF Mono",Monaco,"Cascadia Code",monospace;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-heading:700;--font-weight-extrabold:800;--spacing-0:0;--spacing-1:.25rem;--spacing-2:.5rem;--spacing-3:.75rem;--spacing-4:1rem;--spacing-5:1.25rem;--spacing-6:1.5rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--spacing-16:4rem;--radius-sm:.125rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--radius-full:9999px;--transition-fast:.15s ease;--transition-normal:.3s ease;--transition-slow:.5s ease;--z-dropdown:100;--z-sticky:200;--z-modal:300;--z-toast:400;--border-color:var(--color-border);--border-width:1px;--color-text-primary:var(--color-gray-900);--color-text-secondary:var(--color-gray-700);--color-sidebar-background:var(--color-gray-100);--color-nav-hover:var(--color-gray-200);--color-primary-hover:var(--color-primary-dark);--color-disabled:var(--color-gray-400);--color-tip-background:var(--color-info-light);--color-tip-border:var(--color-info);--color-tip-text:var(--color-info);--color-note-background:var(--color-warning-light);--color-note-border:var(--color-warning);--color-note-text:var(--color-warning);--color-gray-50:#fafafa;--color-success-dark:#2f855a;--color-error-dark:#c53030;--color-warning-dark:#dd6b20;--color-info-dark:#2c5282;--color-primary-lightest:#e3f2fd}
html,body{font-family:var(--font-family-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-background);color:var(--color-text);margin:0;padding:0}*{box-sizing:border-box}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}:focus-visible,button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}ul{padding:0;list-style:none}button{cursor:pointer;font-family:inherit}input,select,textarea,button{font-family:var(--font-family-body)}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}
h1,h2,h3,h4,h5,h6{color:var(--color-gray-900);font-weight:var(--font-weight-heading,var(--font-weight-bold));font-family:var(--font-family-heading);margin:0}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-md)}p{margin:0 0 1rem;line-height:1.6}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-text-secondary)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.text-info{color:var(--color-info)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-md)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.font-normal{font-weight:var(--font-weight-normal)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.font-mono{font-family:var(--font-family-mono)}
.container{max-width:1200px;padding:0 var(--spacing-4);margin:0 auto}.container-fluid{width:100%;padding:0 var(--spacing-4)}.container-sm{max-width:640px;padding:0 var(--spacing-4);margin:0 auto}.container-md{max-width:768px;padding:0 var(--spacing-4);margin:0 auto}.container-lg{max-width:1024px;padding:0 var(--spacing-4);margin:0 auto}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.flex-row{flex-direction:row;display:flex}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.flex-center{justify-content:center;align-items:center;display:flex}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.flex-1{flex:1}.flex-auto{flex:auto}.flex-initial{flex:0 auto}.flex-none{flex:none}.gap-0{gap:0}.gap-1{gap:var(--spacing-1)}.gap-2{gap:var(--spacing-2)}.gap-3{gap:var(--spacing-3)}.gap-4{gap:var(--spacing-4)}.gap-5{gap:var(--spacing-5)}.gap-6{gap:var(--spacing-6)}.gap-8{gap:var(--spacing-8)}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.grid-cols-auto{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.col-span-1{grid-column:span 1}.col-span-2{grid-column:span 2}.col-span-3{grid-column:span 3}.col-span-4{grid-column:span 4}.col-span-full{grid-column:1/-1}.section{padding:var(--spacing-6)0}.section-container{background-color:var(--color-content-background);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-6);margin-bottom:var(--spacing-6)}.section-header{margin-bottom:var(--spacing-6);justify-content:space-between;align-items:center;gap:var(--spacing-4);flex-wrap:wrap;display:flex}.section-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0;margin-bottom:var(--spacing-6);border-bottom:2px solid var(--color-border);padding-bottom:var(--spacing-3)}.section-grid{gap:var(--spacing-6);margin-bottom:var(--spacing-8);display:grid}.section-grid-2{grid-template-columns:repeat(2,1fr)}.section-grid-3{grid-template-columns:repeat(3,1fr)}.section-grid-auto{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.m-0{margin:0}.m-1{margin:var(--spacing-1)}.m-2{margin:var(--spacing-2)}.m-3{margin:var(--spacing-3)}.m-4{margin:var(--spacing-4)}.m-5{margin:var(--spacing-5)}.m-6{margin:var(--spacing-6)}.m-auto{margin:auto}.mt-0{margin-top:0}.mt-1{margin-top:var(--spacing-1)}.mt-2{margin-top:var(--spacing-2)}.mt-3{margin-top:var(--spacing-3)}.mt-4{margin-top:var(--spacing-4)}.mt-5{margin-top:var(--spacing-5)}.mt-6{margin-top:var(--spacing-6)}.mt-8{margin-top:var(--spacing-8)}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--spacing-1)}.mb-2{margin-bottom:var(--spacing-2)}.mb-3{margin-bottom:var(--spacing-3)}.mb-4{margin-bottom:var(--spacing-4)}.mb-5{margin-bottom:var(--spacing-5)}.mb-6{margin-bottom:var(--spacing-6)}.mb-8{margin-bottom:var(--spacing-8)}.ml-0{margin-left:0}.ml-auto{margin-left:auto}.mr-0{margin-right:0}.mr-auto{margin-right:auto}.mx-auto{margin-left:auto;margin-right:auto}.p-0{padding:0}.p-1{padding:var(--spacing-1)}.p-2{padding:var(--spacing-2)}.p-3{padding:var(--spacing-3)}.p-4{padding:var(--spacing-4)}.p-5{padding:var(--spacing-5)}.p-6{padding:var(--spacing-6)}.pt-0{padding-top:0}.pt-4{padding-top:var(--spacing-4)}.pb-0{padding-bottom:0}.pb-4{padding-bottom:var(--spacing-4)}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.hidden{display:none}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.w-full{width:100%}.w-auto{width:auto}.w-half{width:50%}.w-third{width:33.333%}.w-two-thirds{width:66.666%}.h-full{height:100%}.h-auto{height:auto}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-scroll{overflow:scroll}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}@media (max-width:768px){.section-grid-2,.section-grid-3,.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}.container,.container-sm,.container-md,.container-lg{padding:0 var(--spacing-3)}}@media (max-width:480px){.section-container{padding:var(--spacing-4)}}.content-section{background-color:var(--color-content-background);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-8);margin-bottom:var(--spacing-8);border:1px solid var(--color-border)}.content-section-compact{padding:var(--spacing-6);margin-bottom:var(--spacing-6)}.content-section-minimal{padding:var(--spacing-4);margin-bottom:var(--spacing-4);box-shadow:var(--shadow-sm)}.content-section-flat{box-shadow:none;border:1px solid var(--color-border)}.section-subtitle{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-800);margin-bottom:var(--spacing-4);border-bottom:1px solid var(--color-border);padding-bottom:var(--spacing-2)}.section-actions{gap:var(--spacing-3);align-items:center;display:flex}.page-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);margin-bottom:var(--spacing-6);text-align:center}.page-title-left{text-align:left}.page-subtitle{font-size:var(--font-size-lg);color:var(--color-gray-600);margin-bottom:var(--spacing-8);text-align:center}.page-subtitle-left{text-align:left}.summary-section{background:linear-gradient(135deg,var(--color-primary-lightest)0%,var(--color-gray-100)100%);border-left:4px solid var(--color-primary)}.info-section{background-color:var(--color-info-light);border-left:4px solid var(--color-info);border:1px solid var(--color-info)}.warning-section{background-color:var(--color-warning-light);border-left:4px solid var(--color-warning);border:1px solid var(--color-warning)}.error-section{background-color:var(--color-error-light);border-left:4px solid var(--color-error);border:1px solid var(--color-error)}.success-section{background-color:var(--color-success-light);border-left:4px solid var(--color-success);border:1px solid var(--color-success)}.page-container{max-width:1200px;padding:var(--spacing-6);margin:0 auto}.page-container-wide{max-width:1400px}.page-container-narrow{max-width:800px}.page-container-full{width:100%;max-width:none}
.btn{padding:var(--spacing-3)var(--spacing-4);font-size:var(--font-size-md);font-weight:var(--font-weight-medium);font-family:var(--font-family-body);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;gap:var(--spacing-2);border:1px solid #0000;outline:none;min-height:44px;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn:focus{box-shadow:0 0 0 3px #0070f34d}.btn-primary{background-color:var(--color-primary);color:var(--color-white);border-color:var(--color-primary)}.btn-primary:hover{background-color:var(--color-primary-dark);border-color:var(--color-primary-dark);color:var(--color-white);text-decoration:none}.btn-secondary{background-color:var(--color-gray-200);color:var(--color-gray-800);border-color:var(--color-gray-300)}.btn-secondary:hover{background-color:var(--color-gray-300);border-color:var(--color-gray-400);color:var(--color-gray-900);text-decoration:none}.btn-success{background-color:var(--color-success);color:var(--color-white);border-color:var(--color-success)}.btn-success:hover{background-color:var(--color-success-dark);color:var(--color-white);text-decoration:none}.btn-warning{background-color:var(--color-warning);color:var(--color-white);border-color:var(--color-warning)}.btn-warning:hover{background-color:var(--color-warning-dark);color:var(--color-white);text-decoration:none}.btn-danger{background-color:var(--color-error);color:var(--color-white);border-color:var(--color-error)}.btn-danger:hover{background-color:var(--color-error-dark);color:var(--color-white);text-decoration:none}.btn-info{background-color:var(--color-info);color:var(--color-white);border-color:var(--color-info)}.btn-info:hover{background-color:var(--color-info-dark);color:var(--color-white);text-decoration:none}.btn-ghost{color:var(--color-gray-700);background-color:#0000;border-color:#0000}.btn-ghost:hover{background-color:var(--color-gray-200);color:var(--color-gray-900);text-decoration:none}.btn-outline-primary{color:var(--color-primary);border-color:var(--color-primary);background-color:#0000}.btn-outline-primary:hover{background-color:var(--color-primary);color:var(--color-white);text-decoration:none}.btn-outline-secondary{color:var(--color-gray-700);border-color:var(--color-gray-400);background-color:#0000}.btn-outline-secondary:hover{background-color:var(--color-gray-200);color:var(--color-gray-900);border-color:var(--color-gray-500);text-decoration:none}.btn-outline-danger{color:var(--color-error);border-color:var(--color-error);background-color:#0000}.btn-outline-danger:hover{background-color:var(--color-error);color:var(--color-white);text-decoration:none}.btn-sm{padding:var(--spacing-2)var(--spacing-3);font-size:var(--font-size-sm);min-height:36px}.btn-lg{padding:var(--spacing-4)var(--spacing-6);font-size:var(--font-size-lg);min-height:52px}.btn-block{width:100%;display:flex}.btn-group,.button-group{gap:var(--spacing-2);flex-wrap:wrap;display:flex}.btn-group-vertical{gap:var(--spacing-2);flex-direction:column;display:flex}.btn-group-connected{gap:0;display:flex}.btn-group-connected .btn{border-radius:0}.btn-group-connected .btn:first-child{border-top-left-radius:var(--radius-md);border-bottom-left-radius:var(--radius-md)}.btn-group-connected .btn:last-child{border-top-right-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md)}.btn-group-connected .btn:not(:last-child){border-right:none}.import-button{background-color:var(--color-success);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;transition:background-color .2s,transform .1s;display:inline-block;box-shadow:0 2px 4px #0000001a}.import-button:hover{background-color:var(--color-success-dark);transform:translateY(-1px);box-shadow:0 3px 6px #00000026}.import-button:active{transform:translateY(0);box-shadow:0 2px 4px #0000001a}@media (max-width:768px){.button-group{flex-direction:column;width:100%}.button-group .btn{justify-content:center;width:100%}}
.form{gap:var(--spacing-4);padding:var(--spacing-6);flex-direction:column;margin:0;display:flex}.form-horizontal{gap:var(--spacing-4);flex-flow:wrap;display:flex}.form-inline{gap:var(--spacing-3);flex-direction:row;align-items:center;display:flex}.form-group,.formGroup{gap:var(--spacing-2);margin-bottom:var(--spacing-4);flex-direction:column;display:flex}.form-group:last-child{margin-bottom:0}.form-group label,.formGroup label{font-weight:var(--font-weight-medium);color:var(--color-text-primary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-2)}.form-group-horizontal,.formGroupInline{align-items:center;gap:var(--spacing-4);flex-direction:row;display:flex}.form-group-horizontal label{flex:none;min-width:120px;margin-bottom:0}.formGroupInline label{flex:1}.formGroupInline input{width:100%}.form-control,.formControl{padding:var(--spacing-3);border:1px solid var(--color-input-border);border-radius:var(--radius-md);font-size:var(--font-size-md);font-family:var(--font-family-body);background-color:var(--color-white);color:var(--color-text);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.form-control:focus,.formControl:focus{border-color:var(--color-input-focus);outline:none;box-shadow:0 0 0 3px #0070f31a}.form-control:disabled,.formControl:disabled{background-color:var(--color-gray-100);color:var(--color-gray-500);cursor:not-allowed;opacity:.7}.form-control::placeholder{color:var(--color-gray-500)}.form-control-sm{padding:var(--spacing-2);font-size:var(--font-size-sm)}.form-control-lg{padding:var(--spacing-4);font-size:var(--font-size-lg)}input[type=text].form-control,input[type=email].form-control,input[type=password].form-control,input[type=number].form-control,input[type=date].form-control,input[type=time].form-control{width:100%}input[type=checkbox],input[type=radio]{cursor:pointer;margin-right:var(--spacing-2)}textarea.form-control{resize:vertical;min-height:100px;font-family:inherit}select.form-control{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23555' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--spacing-3)center;padding-right:var(--spacing-8);background-size:16px}input[type=file].form-control{padding:var(--spacing-2)}.checkbox,.radio{align-items:center;gap:var(--spacing-2);cursor:pointer;display:flex}.checkbox input,.radio input{margin:0;margin-right:var(--spacing-2)}.checkboxGroup,.checkbox-group{gap:var(--spacing-4);flex-wrap:wrap;display:flex}.checkboxLabel{align-items:center;gap:var(--spacing-2);cursor:pointer;display:flex}.form-row,.formRow{gap:var(--spacing-4);align-items:flex-start;display:flex}.form-row .form-group,.formRow .formGroup{flex:1;margin-bottom:0}.form-actions,.formActions{justify-content:flex-end;gap:var(--spacing-4);margin-top:var(--spacing-6);padding-top:var(--spacing-4);border-top:1px solid var(--color-border);display:flex}.form-control.error,.form-control.inputError{border-color:var(--color-error)}.form-control.error:focus{box-shadow:0 0 0 3px #e53e3e1a}.form-error,.errorText{color:var(--color-error);font-size:var(--font-size-sm);margin-top:var(--spacing-1);display:block}.form-help{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--spacing-1);display:block}.form-control.success{border-color:var(--color-success)}.form-control.success:focus{box-shadow:0 0 0 3px #22c55e1a}.form-success{color:var(--color-success);font-size:var(--font-size-sm);margin-top:var(--spacing-1)}.input-group{align-items:stretch;display:flex}.input-addon,.inputAddon{background-color:var(--color-gray-200);padding:var(--spacing-3)var(--spacing-4);border:1px solid var(--color-input-border);border-radius:var(--radius-md)0 0 var(--radius-md);font-size:var(--font-size-md);color:var(--color-gray-700);border-right:none;align-items:center;display:flex}.input-group .form-control{border-radius:0 var(--radius-md)var(--radius-md)0;flex:1}@media (max-width:768px){.form-row,.formRow,.form-horizontal{flex-direction:column}.form-actions,.formActions{flex-direction:column-reverse}.form-actions .btn,.formActions .btn{width:100%}.form-group-horizontal{flex-direction:column;align-items:flex-start}.form-group-horizontal label{min-width:auto}}
.year-badges{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.year-badge{background-color:var(--color-gray-100);border:1px solid var(--color-gray-300);cursor:pointer;border-radius:1rem;padding:.25rem .75rem;font-size:.85rem;transition:all .2s}.year-badge:hover{background-color:var(--color-gray-200)}.active-year-badge{background-color:var(--color-primary);color:var(--color-white);border-color:var(--color-primary)}.clear-year-filters{background-color:var(--color-error);color:var(--color-white);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;margin-left:5px;font-size:12px;display:flex}.clear-year-filters:hover{background-color:var(--color-error-dark)}.delete-mode{background-color:var(--color-warning-light);border:1px solid var(--color-warning);color:var(--color-warning-dark);border-radius:4px;margin-bottom:15px;padding:10px 15px}.delete-mode p{align-items:center;gap:8px;margin:0;display:flex}.filter-controls{flex-direction:column;gap:10px;margin-bottom:20px;display:flex}.filter-toggles{gap:20px;margin-bottom:10px;display:flex}.filter-toggle{align-items:center;gap:8px;display:flex}.filter-toggle input{margin:0}.filter-toggle label{color:var(--color-text-primary)}.filter-options{gap:10px;display:flex}.filter-select{border:1px solid var(--color-input-border);background-color:var(--color-white);color:var(--color-text-primary);border-radius:4px;padding:8px}.empty-state{text-align:center;background-color:var(--color-gray-100);border:1px dashed var(--color-border);border-radius:8px;padding:30px}.empty-state p{color:var(--color-text-secondary);margin-bottom:15px}.payment-list{margin:0 0 30px;padding:0;list-style:none}.payment-item{border:1px solid var(--color-border);background:linear-gradient(135deg,var(--color-content-background),#fffc);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;margin-bottom:24px;padding:24px;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 4px 12px #00000014,0 2px 4px #0000000a}.payment-item:before{content:"";background:linear-gradient(45deg,var(--color-primary),var(--color-primary-light),var(--color-info));background-size:200% 200%;border-radius:0 3px 3px 0;width:5px;height:100%;transition:all .4s cubic-bezier(.4,0,.2,1);animation:3s infinite gradientShift;position:absolute;top:0;left:0}@keyframes gradientShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}.payment-item:hover{border-color:var(--color-primary);background:linear-gradient(135deg,#fffffff2,#0070f305);transform:translateY(-4px)scale(1.01);box-shadow:0 8px 32px #0070f326,0 4px 12px #0000001a}.payment-item:hover:before{width:8px;box-shadow:0 0 20px #0070f366}.payment-item small{color:var(--color-text-secondary);margin-top:.25rem}.payment-info{flex-direction:column;gap:8px;width:100%;display:flex}.payment-main{justify-content:space-between;align-items:center;gap:16px;display:flex}.payment-source{color:var(--color-text-primary);letter-spacing:-.02em;font-size:1.1rem;font-weight:600;line-height:1.3}.payment-date{color:var(--color-text-secondary);font-size:.9rem;font-weight:500}.payment-invoice{color:var(--color-text-secondary);background:var(--color-gray-100);border-radius:4px;padding:4px 8px;font-size:.85rem;font-weight:500}.payment-tags{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.expense-header{border-bottom:2px solid var(--color-gray-100);justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding-bottom:12px;display:flex;position:relative}.expense-header:after{content:"";background:linear-gradient(90deg,var(--color-primary),var(--color-primary-light));border-radius:1px;width:60px;height:2px;position:absolute;bottom:-2px;left:0}.expense-title{flex-direction:column;flex:1;gap:6px;display:flex}.expense-title strong{color:var(--color-text-primary);letter-spacing:-.02em;margin-bottom:4px;font-size:1.3rem;font-weight:600;line-height:1.3}.payment-amount{color:var(--color-success);background:linear-gradient(135deg,var(--color-success-light),#19783714);border:1px solid var(--color-success);border-radius:8px;width:fit-content;padding:8px 12px;font-size:1.2rem;font-weight:700;transition:all .3s;display:inline-block;box-shadow:0 2px 4px #1978371a}.payment-amount:hover{transform:translateY(-1px);box-shadow:0 4px 8px #19783733}.expense-actions{align-items:flex-start;gap:10px;display:flex}.edit-button{background:linear-gradient(135deg,var(--color-gray-100),var(--color-gray-200));border:1px solid var(--color-gray-300);color:var(--color-gray-700);cursor:pointer;border-radius:8px;padding:8px 16px;font-size:.85rem;font-weight:500;transition:all .2s;box-shadow:0 1px 3px #0000001a}.edit-button:hover{background:linear-gradient(135deg,var(--color-gray-200),var(--color-gray-300));border-color:var(--color-gray-400);color:var(--color-gray-900);transform:translateY(-1px);box-shadow:0 2px 6px #00000026}.delete-button{background:linear-gradient(135deg,var(--color-error-light),var(--color-error));border:1px solid var(--color-error);color:var(--color-white);cursor:pointer;border-radius:8px;padding:8px 16px;font-size:.85rem;font-weight:500;transition:all .2s;box-shadow:0 1px 3px #0000001a}.delete-button:hover{background:linear-gradient(135deg,var(--color-error),var(--color-error-dark));border-color:var(--color-error-dark);color:var(--color-white);transform:translateY(-1px);box-shadow:0 2px 6px #dc354533}.expense-description{color:var(--color-text-secondary);background:var(--color-gray-50);border-left:3px solid var(--color-gray-300);border-radius:8px;margin-bottom:14px;padding:12px 16px;font-size:.96rem;line-height:1.6}.expense-details{color:var(--color-text-secondary);flex-wrap:wrap;gap:16px;margin-top:8px;padding:12px 0;font-size:.88rem;display:flex}.expense-date{color:var(--color-text);align-items:center;font-weight:500;display:flex}.payment-details{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.actionButton{background-color:var(--color-primary);color:var(--color-white);cursor:pointer;border:none;border-radius:8px;margin-bottom:1.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;transition:background-color .2s,transform .1s;display:inline-block;box-shadow:0 2px 4px #0000001a}.actionButton:hover{background-color:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.tax-badge{background:linear-gradient(135deg,var(--color-success),var(--color-success-dark));color:var(--color-white);border-radius:16px;padding:6px 12px;font-size:.75rem;font-weight:600;transition:all .2s;box-shadow:0 2px 4px #4caf504d}.tax-badge:hover{transform:translateY(-1px);box-shadow:0 4px 8px #4caf5066}.cc-badge{background:linear-gradient(135deg,var(--color-info),var(--color-info-dark));color:var(--color-white);border-radius:16px;padding:6px 12px;font-size:.75rem;font-weight:600;transition:all .2s;box-shadow:0 2px 4px #2196f34d}.cc-badge:hover{transform:translateY(-1px);box-shadow:0 4px 8px #2196f366}.attachment-link{text-decoration:none}.attachment-badge{background:linear-gradient(135deg,var(--color-info-light),#3182ce1a);color:var(--color-info);border:1px solid var(--color-info);border-radius:16px;align-items:center;margin-left:8px;padding:6px 12px;font-size:.75rem;font-weight:600;transition:all .2s;display:inline-flex;box-shadow:0 2px 4px #3182ce1a}.attachment-badge:hover{background:linear-gradient(135deg,#3182ce1a,var(--color-info-light));transform:translateY(-1px);box-shadow:0 4px 8px #3182ce33}.show-more-container{justify-content:center;margin:1rem 0 2rem;display:flex}.show-more-button{background-color:var(--color-gray-100);border:1px solid var(--color-gray-300);color:var(--color-gray-700);cursor:pointer;border-radius:20px;padding:.5rem 1.5rem;font-size:.9rem;transition:all .2s}.show-more-button:hover{background-color:var(--color-gray-200);border-color:var(--color-gray-400);transform:translateY(-1px)}.statistics{flex-flow:wrap;justify-content:space-between;margin:2rem 0;display:flex}.stat-box{background-color:var(--color-content-background);border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.stat-box h3{color:var(--color-text-primary);margin-top:0;font-size:1rem}.stat-box p{color:var(--color-primary);margin:.5rem 0 0;font-size:1.5rem;font-weight:700}.chart-container{background-color:var(--color-content-background);border-radius:8px;margin-top:1rem;padding:1rem;box-shadow:0 1px 3px #0000001a}@media (max-width:768px){.statistics{grid-template-columns:1fr}.filter-options{flex-direction:column}.filter-select{width:100%}.payment-details{flex-direction:column}.filter-controls{margin-bottom:1rem}.filter-toggles{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:15px}}@media (max-width:480px){.content-section{padding:1rem}.payment-item{padding:10px}.expense-header{flex-direction:column;align-items:flex-start}.expense-actions{flex-direction:column;justify-content:flex-end;gap:5px;width:100%;margin-top:10px}.year-badges{justify-content:flex-start;width:100%;margin-top:10px}}
.summary-banner{gap:var(--spacing-4);margin-bottom:var(--spacing-6);margin-top:var(--spacing-6);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));display:grid}.banner-item{background-color:var(--color-content-background);padding:var(--spacing-6);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);text-align:center;border:1px solid var(--color-border);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.banner-item:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.banner-item h3{margin:0 0 var(--spacing-2)0;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.5px}.banner-item .value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.banner-item .value.positive{color:var(--color-success)}.banner-item .value.negative{color:var(--color-error)}.view-all-link{color:var(--color-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:color var(--transition-fast);margin:0}.view-all-link:hover{color:var(--color-primary-dark);text-decoration:underline}.no-items{text-align:center;color:var(--color-text-secondary);padding:var(--spacing-6);background-color:var(--color-gray-100);border-radius:var(--radius-md);border:1px dashed var(--color-border);margin:var(--spacing-4)0;font-style:italic}.demo-banner{background:linear-gradient(135deg,var(--color-warning-light)0%,var(--color-info-light)100%);border:1px solid var(--color-warning);border-radius:var(--radius-md);padding:var(--spacing-4);margin-bottom:var(--spacing-6);color:var(--color-text-primary);text-align:center;box-shadow:var(--shadow-md)}.demo-banner strong{color:var(--color-warning);font-weight:var(--font-weight-bold)}.demo-banner a{color:var(--color-primary);font-weight:var(--font-weight-medium);text-decoration:underline}
.chart-legend{margin-top:var(--spacing-4);padding:var(--spacing-4);background-color:var(--color-gray-100);border-radius:var(--radius-md);border:1px solid var(--color-border)}.chart-legend p{margin:var(--spacing-2)0;font-size:var(--font-size-sm);color:var(--color-text-secondary);align-items:center;gap:var(--spacing-2);display:flex}.chart-average{color:var(--color-info);font-weight:var(--font-weight-bold);font-size:var(--font-size-lg)}.chart-line{color:var(--color-error);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);letter-spacing:1px}.chart-average-exp{color:var(--color-error);font-weight:var(--font-weight-bold);font-size:var(--font-size-lg)}.chart-expense-line{color:var(--color-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);letter-spacing:1px}.chart-2024-line{color:var(--color-info);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);letter-spacing:1px}
.table{border-collapse:collapse;background-color:var(--color-white);border-radius:var(--radius-md);width:100%;box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-4);overflow:hidden}.table th,.table td{padding:var(--spacing-3)var(--spacing-4);text-align:left;border-bottom:1px solid var(--color-border)}.table th{background-color:var(--color-gray-100);color:var(--color-gray-800);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.025em}.table td{color:var(--color-gray-700);vertical-align:top}.table tr:nth-child(2n){background-color:var(--color-gray-50)}.table tr:hover{background-color:var(--color-gray-100)}.table tr:last-child td{border-bottom:none}.table-compact{font-size:var(--font-size-sm)}.table-compact th,.table-compact td{padding:var(--spacing-2)var(--spacing-3)}.table-spacious th,.table-spacious td{padding:var(--spacing-4)var(--spacing-6)}.table-borderless{box-shadow:none}.table-borderless th,.table-borderless td{border:none}.table-striped tr:nth-child(2n){background-color:var(--color-gray-50)}.table-hoverable tr:hover{background-color:var(--color-gray-100);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.table-primary th{background-color:var(--color-primary);color:var(--color-white)}.table-success th{background-color:var(--color-success);color:var(--color-white)}.table-warning th{background-color:var(--color-warning);color:var(--color-white)}.table-error th{background-color:var(--color-error);color:var(--color-white)}.table-info th{background-color:var(--color-info);color:var(--color-white)}.table .total-row{font-weight:var(--font-weight-bold);background-color:var(--color-gray-200);color:var(--color-gray-900)}.table .total-row td{border-top:2px solid var(--color-gray-400);border-bottom:2px solid var(--color-gray-400);font-size:var(--font-size-md)}.table .highlight-row{background-color:var(--color-info-light)}.table .error-row{background-color:var(--color-error-light)}.table .success-row{background-color:var(--color-success-light)}.table .warning-row{background-color:var(--color-warning-light)}.table-container{background-color:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-bottom:var(--spacing-6);overflow:hidden}.table-wrapper{-webkit-overflow-scrolling:touch;width:100%;max-height:600px;overflow:auto}.table-wrapper.scrollable{border:1px solid var(--color-border);border-radius:var(--radius-md);max-height:400px}.report-table{box-shadow:var(--shadow-md);margin-bottom:var(--spacing-6)}.report-table th{background-color:var(--color-gray-200);font-weight:var(--font-weight-bold);z-index:10;position:sticky;top:0}.results-table{font-size:var(--font-size-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.results-table th{background-color:var(--color-gray-100);z-index:10;box-shadow:0 1px 0 var(--color-border);position:sticky;top:0}.preview-table{font-size:var(--font-size-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);max-height:300px;margin-bottom:var(--spacing-4);overflow:hidden}.preview-table th{background-color:var(--color-gray-100);z-index:10;box-shadow:0 1px 0 var(--color-border);position:sticky;top:0}.tax-table th{background-color:var(--color-info-light);color:var(--color-info);font-weight:var(--font-weight-bold)}.table .text-left{text-align:left}.table .text-center{text-align:center}.table .text-right{text-align:right}.table .align-top{vertical-align:top}.table .align-middle{vertical-align:middle}.table .align-bottom{vertical-align:bottom}.table .col-auto{width:auto}.table .col-narrow{width:10%}.table .col-small{width:15%}.table .col-medium{width:25%}.table .col-large{width:40%}.table .col-full{width:100%}@media (max-width:768px){.table{font-size:var(--font-size-sm)}.table th,.table td{padding:var(--spacing-2)var(--spacing-3)}.table-wrapper{margin-bottom:var(--spacing-4)}.report-table,.results-table,.preview-table{min-width:500px}.table-container{margin-bottom:var(--spacing-4);border-radius:var(--radius-md)}.statistics{flex-direction:row}}@media (max-width:480px){.table{font-size:var(--font-size-xs)}.table th,.table td{padding:var(--spacing-2)}.table-wrapper{border-radius:var(--radius-sm)}.statistics{flex-direction:column}}
.list{margin:0;padding:0;list-style:none}.list-spaced{margin:var(--spacing-4)0;padding:0;list-style:none}.list-compact{margin:var(--spacing-2)0;padding:0;list-style:none}.list-ordered{padding-left:var(--spacing-6);margin:var(--spacing-4)0;list-style-type:decimal}.list-bulleted{padding-left:var(--spacing-6);margin:var(--spacing-4)0;list-style-type:disc}.list-unstyled,.list-interactive,.list-hoverable{margin:0;padding:0;list-style:none}.list-item{padding:var(--spacing-3);margin-bottom:var(--spacing-2);background-color:var(--color-content-background);border-radius:var(--radius-md);border:1px solid var(--color-border);transition:var(--transition-fast)}.list-item:last-child{margin-bottom:0}.list-item-compact{padding:var(--spacing-2);margin-bottom:var(--spacing-1);background-color:var(--color-content-background);border-radius:var(--radius-sm);border:1px solid var(--color-border);transition:var(--transition-fast)}.list-item-spacious{padding:var(--spacing-5);margin-bottom:var(--spacing-4);background-color:var(--color-content-background);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.list-item-flat{padding:var(--spacing-3);margin-bottom:var(--spacing-2);border:none;border-bottom:1px solid var(--color-border);transition:var(--transition-fast);background-color:#0000;border-radius:0}.list-item-elevated{padding:var(--spacing-4);margin-bottom:var(--spacing-3);background-color:var(--color-content-background);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-md);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.list-item-interactive,.list-item:hover{background-color:var(--color-nav-hover);border-color:var(--color-primary-light);cursor:pointer}.list-item-spacious:hover,.list-item-elevated:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.list-item-clickable{cursor:pointer;transition:var(--transition-fast)}.list-item-clickable:hover{background-color:var(--color-nav-hover);border-color:var(--color-primary-light)}.payment-list{margin:var(--spacing-4)0;padding:0;list-style:none}.payment-item{border:1px solid var(--color-border);background-color:var(--color-content-background);box-shadow:var(--shadow-sm);border-radius:8px;margin-bottom:16px;padding:16px;transition:transform .2s,box-shadow .2s}.payment-item:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.payment-item small{color:var(--color-text-secondary);margin-top:.25rem}.payment-details{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.expense-list{margin:var(--spacing-4)0;padding:0;list-style:none}.expense-item{background-color:var(--color-content-background);border-radius:var(--radius-md);padding:var(--spacing-3);margin-bottom:var(--spacing-3);border:1px solid var(--color-border);transition:var(--transition-fast)}.expense-item:hover{background-color:var(--color-nav-hover);border-color:var(--color-primary-light)}.expense-info{margin-bottom:var(--spacing-1);justify-content:space-between;display:flex}.expense-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.expense-amount{font-weight:var(--font-weight-semibold);color:var(--color-expense)}.expense-date{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.expense-header{margin-bottom:var(--spacing-2);justify-content:space-between;align-items:flex-start;display:flex}.expense-title{gap:var(--spacing-1);flex-direction:column;display:flex}.expense-title strong{font-size:var(--font-size-lg);color:var(--color-text-primary)}.expense-description{color:var(--color-text-secondary);margin-bottom:10px;font-size:.95rem}.expense-details{gap:var(--spacing-3);font-size:var(--font-size-sm);color:var(--color-text-secondary);flex-wrap:wrap;display:flex}.expense-actions{gap:var(--spacing-2);margin-top:var(--spacing-2);display:flex}.results-list{border:1px solid var(--color-border);border-radius:var(--radius-md);margin:var(--spacing-5)0;max-height:400px;overflow:hidden auto}.results-list-large{max-height:600px}.results-list-compact{max-height:300px}.nav-list{margin:0;padding:0;list-style-type:none}.nav-item{margin-bottom:var(--spacing-3)}.nav-link{padding:var(--spacing-3);color:var(--color-text-primary);border-radius:var(--radius-md);transition:var(--transition-fast);cursor:pointer;text-decoration:none;display:block}.nav-link:hover{background-color:var(--color-nav-hover);color:var(--color-text-primary);text-decoration:none}.nav-link-active{background-color:var(--color-primary);color:var(--color-white);font-weight:var(--font-weight-medium)}.sidebar-list{margin:0;padding:0;list-style:none}.sidebar-button{text-align:left;width:100%;padding:var(--spacing-3);margin-bottom:var(--spacing-2);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-sm);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none}.sidebar-button:hover{background-color:var(--color-nav-hover)}.sidebar-button-active{background-color:var(--color-primary);color:var(--color-white);font-weight:var(--font-weight-medium)}.step-list{counter-reset:steps;padding-left:var(--spacing-3);margin:var(--spacing-4)0;list-style-type:none}.step-list li{margin-bottom:var(--spacing-4);padding-left:var(--spacing-9);counter-increment:steps;position:relative}.step-list li:before{content:counter(steps);background-color:var(--color-primary);width:25px;height:25px;color:var(--color-white);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:0;left:0}.credential-list{margin:var(--spacing-4)0;padding:0;list-style:none}.credential-item{padding:var(--spacing-4);margin-bottom:var(--spacing-3);background-color:var(--color-content-background);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:var(--transition-fast)}.credential-item:hover{background-color:var(--color-nav-hover);border-color:var(--color-primary-light)}.list-empty{text-align:center;padding:var(--spacing-8);background-color:var(--color-gray-100);border-radius:var(--radius-md);border:1px dashed var(--color-border);color:var(--color-text-secondary);font-style:italic}.list-empty p{margin-bottom:var(--spacing-4)}.list-loading{text-align:center;padding:var(--spacing-8);color:var(--color-text-secondary);font-size:var(--font-size-lg)}.list-item-selected{background-color:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary-dark)}.list-item-highlighted{background-color:var(--color-warning-light);border-color:var(--color-warning)}.list-item-error{background-color:var(--color-error-light);border-color:var(--color-error)}.list-item-success{background-color:var(--color-success-light);border-color:var(--color-success)}.list-item-warning{background-color:var(--color-warning-light);border-color:var(--color-warning)}.list-item-info{background-color:var(--color-info-light);border-color:var(--color-info)}
.card{background-color:var(--color-content-background);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-6);margin-bottom:var(--spacing-6);border:1px solid var(--color-border);transition:box-shadow var(--transition-fast),transform var(--transition-fast)}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-compact{padding:var(--spacing-4);margin-bottom:var(--spacing-4)}.card-spacious{padding:var(--spacing-8);margin-bottom:var(--spacing-8)}.card-flat{box-shadow:none;border:1px solid var(--color-border)}.card-elevated{box-shadow:var(--shadow-xl)}.card-interactive{cursor:pointer;transition:all var(--transition-fast)}.card-interactive:hover{box-shadow:var(--shadow-xl);border-color:var(--color-primary);transform:translateY(-4px)}.card-primary{border-left:4px solid var(--color-primary);background-color:#0070f305}.card-success{border-left:4px solid var(--color-success);background-color:#4caf5005}.card-warning{border-left:4px solid var(--color-warning);background-color:#ff980005}.card-error{border-left:4px solid var(--color-error);background-color:#f4433605}.card-info{border-left:4px solid var(--color-info);background-color:#2196f305}.card-header{margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-3);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-gray-900);margin:0}.card-subtitle{font-size:var(--font-size-sm);color:var(--color-gray-600);margin:var(--spacing-1)0 0 0}.card-body{flex:1}.card-text{color:var(--color-gray-700);margin-bottom:var(--spacing-4);line-height:1.5}.card-footer{margin-top:var(--spacing-4);padding-top:var(--spacing-3);border-top:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.card-actions{gap:var(--spacing-2);align-items:center;display:flex}.profile-card{text-align:center}.summary-card{text-align:center;background:linear-gradient(135deg,var(--color-content-background)0%,var(--color-gray-100)100%)}.summary-card .card-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary)}.nav-card{padding:var(--spacing-6);text-align:center;transition:all var(--transition-normal);cursor:pointer;border:2px solid var(--color-border)}.nav-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.nav-card .card-title{color:var(--color-gray-900);margin-bottom:var(--spacing-3)}.nav-card .card-text{color:var(--color-gray-600);margin-bottom:var(--spacing-4)}.card-grid{gap:var(--spacing-6);margin-bottom:var(--spacing-6);display:grid}.card-grid-2{grid-template-columns:repeat(2,1fr)}.card-grid-3{grid-template-columns:repeat(3,1fr)}.card-grid-4{grid-template-columns:repeat(4,1fr)}.card-grid-auto{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}
.badge{padding:var(--spacing-1)var(--spacing-2);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.025em;display:inline-block}.badge-primary{background-color:var(--color-primary);color:var(--color-white)}.badge-secondary{background-color:var(--color-gray-200);color:var(--color-gray-800)}.badge-success{background-color:var(--color-success);color:var(--color-white)}.badge-warning{background-color:var(--color-warning);color:var(--color-white)}.badge-error{background-color:var(--color-error);color:var(--color-white)}.badge-info{background-color:var(--color-info);color:var(--color-white)}.badge-outline{background-color:#0000;border:1px solid}.badge-light{background-color:var(--color-gray-100);color:var(--color-gray-800)}.badge-dark{background-color:var(--color-gray-800);color:var(--color-white)}.tax-badge{background-color:var(--color-success);color:var(--color-white)}.cc-badge{background-color:var(--color-info);color:var(--color-white)}.category-badge{background-color:var(--color-secondary);color:var(--color-white)}.recurring-badge{background-color:var(--color-warning);color:var(--color-black)}.attachment-badge{background-color:var(--color-gray-200);color:var(--color-gray-800);border:1px solid var(--color-gray-300)}.year-badge{background-color:var(--color-gray-100);color:var(--color-gray-800);border:1px solid var(--color-gray-300);cursor:pointer;transition:all .2s}.year-badge:hover{background-color:var(--color-gray-200)}.year-badge.active{background-color:var(--color-primary);color:var(--color-white);border-color:var(--color-primary)}.found-badge{background-color:var(--color-success-light);color:var(--color-success-dark)}.missing-badge{background-color:var(--color-error-light);color:var(--color-error-dark)}.addon-badge{background-color:var(--color-info);color:var(--color-white);text-transform:capitalize}
.dark-theme{--color-primary:#3291ff;--color-primary-dark:#1e88e5;--color-primary-light:#64b5f6;--color-secondary:#9575cd;--color-secondary-dark:#7e57c2;--color-background:#121212;--color-white:#1e1e1e;--color-content-background:#1e1e1e;--color-gray-100:#2d2d2d;--color-gray-200:#333;--color-gray-300:#474747;--color-gray-400:#5c5c5c;--color-gray-500:#8a8a8a;--color-gray-600:#a0a0a0;--color-gray-700:#d4d4d4;--color-gray-800:#e8e8e8;--color-gray-900:#f5f5f5;--color-text:#e8e8e8;--color-border:#333;--color-input-border:#474747;--color-success:#4caf50;--color-success-light:#4caf5033;--color-warning:#ff9800;--color-warning-light:#ff980033;--color-error:#f44336;--color-error-light:#f4433633;--color-info:#2196f3;--color-info-light:#2196f333;--shadow-sm:0 1px 2px #0003;--shadow-md:0 2px 4px #0000004d;--shadow-lg:0 4px 6px #0000004d;--shadow-xl:0 10px 15px #0006;--color-text-primary:#e8e8e8;--color-text-secondary:#a0a0a0;--color-sidebar-background:#2d2d2d;--color-nav-hover:#333;--color-primary-hover:#1e88e5;--color-disabled:#5c5c5c;--color-tip-background:#2196f31a;--color-tip-border:#2196f3;--color-tip-text:#64b5f6;--color-note-background:#ff98001a;--color-note-border:#ff9800;--color-note-text:#ffb74d;--font-family-heading:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-family-body:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-family-mono:"SF Mono",Monaco,"Cascadia Code",monospace;--text-color:#fff;--input-bg:#2a2a2a;--border-color:#444}.dark-theme .table{background-color:var(--color-gray-800);color:var(--color-gray-100)}.dark-theme .table th{background-color:var(--color-gray-700);color:var(--color-gray-100)}.dark-theme .table td{color:var(--color-gray-200);border-bottom-color:var(--color-gray-600)}.dark-theme .table tr:nth-child(2n){background-color:var(--color-gray-750)}.dark-theme .table tr:hover{background-color:var(--color-gray-700)}.dark-theme .table .total-row{background-color:var(--color-gray-600);color:var(--color-gray-100)}.dark-theme .table .total-row td{border-top-color:var(--color-gray-500);border-bottom-color:var(--color-gray-500)}.dark-theme .table-container{background-color:var(--color-gray-800)}.dark-theme .table-wrapper.scrollable{border-color:var(--color-gray-600)}.dark-theme .list-item,.dark-theme .payment-item,.dark-theme .expense-item,.dark-theme .credential-item{background-color:var(--color-content-background);border-color:var(--color-border)}.dark-theme .list-item:hover,.dark-theme .payment-item:hover,.dark-theme .expense-item:hover,.dark-theme .nav-link:hover,.dark-theme .sidebar-button:hover{background-color:var(--color-nav-hover)}.dark-theme .form-control{background-color:var(--color-gray-800);border-color:var(--color-gray-600);color:var(--color-gray-100)}.dark-theme .form-control:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #3291ff1a}.dark-theme .form-control:disabled{background-color:var(--color-gray-700);color:var(--color-gray-500)}.dark-theme .banner-item{background-color:var(--color-gray-800);border-color:var(--color-gray-700)}.dark-theme .no-items{background-color:var(--color-gray-800);border-color:var(--color-gray-600)}.dark-theme .demo-banner{border-color:var(--color-warning);color:var(--color-text);background:linear-gradient(135deg,#ff980033 0%,#2196f333 100%)}.dark-theme .chart-legend{background-color:var(--color-gray-800);border-color:var(--color-gray-700)}.dark-theme .error-container{border-color:var(--color-error);background-color:#f443361a}.dark-theme .error-container h2{color:#ff8a80}.dark-theme .error-container p{color:var(--color-gray-300)}
.cyberpunk-theme{--color-primary:#0ff;--color-primary-dark:#00b8d4;--color-primary-light:#4dd0e1;--color-secondary:#ff0080;--color-secondary-dark:#c2185b;--color-background:#0a0a0a;--color-white:#1a1a1a;--color-content-background:#1a1a1a;--color-gray-100:#262626;--color-gray-200:#333;--color-gray-300:#404040;--color-gray-400:#525252;--color-gray-500:#737373;--color-gray-600:#a3a3a3;--color-gray-700:#d4d4d4;--color-gray-800:#f5f5f5;--color-gray-900:#fff;--color-text:#0ff;--color-border:#ff0080;--color-input-border:#0ff;--color-success:#39ff14;--color-success-light:#39ff1433;--color-warning:#ff0;--color-warning-light:#ff03;--color-error:#ff073a;--color-error-light:#ff073a33;--color-info:#0ff;--color-info-light:#0ff3;--shadow-sm:0 0 4px #00ffff4d;--shadow-md:0 0 8px #0ff6;--shadow-lg:0 0 12px #00ffff80;--shadow-xl:0 0 20px #0ff9;--color-text-primary:#0ff;--color-text-secondary:#ff0080;--color-sidebar-background:#1a1a1a;--color-nav-hover:#262626;--color-primary-hover:#00b8d4;--color-disabled:#525252;--color-tip-background:#00ffff1a;--color-tip-border:#0ff;--color-tip-text:#4dd0e1;--color-note-background:#ffff001a;--color-note-border:#ff0;--color-note-text:#ffff8d;--font-family-heading:"Orbitron","Exo 2",sans-serif;--font-family-body:"Inter","Roboto Mono",monospace;--font-family-mono:"Fira Code","Source Code Pro",monospace;font-family:var(--font-family-body);--font-weight-heading:600;--font-weight-body:400;--font-weight-bold:700;text-shadow:0 0 2px}.cyberpunk-theme h1,.cyberpunk-theme h2,.cyberpunk-theme h3,.cyberpunk-theme h4,.cyberpunk-theme h5,.cyberpunk-theme h6{color:#0ff;text-shadow:0 0 10px #0ffc;font-family:var(--font-family-heading);font-weight:var(--font-weight-heading)}.cyberpunk-theme .table{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a0a0ae6;border:1px solid #0ff;box-shadow:0 0 15px #00ffff4d}.cyberpunk-theme .table th{color:#0ff;text-shadow:0 0 5px #0ffc;font-weight:var(--font-weight-bold);background:linear-gradient(135deg,#1a1a1a 0%,#262626 100%);border:1px solid #0ff;position:relative}.cyberpunk-theme .table th:after{content:"";pointer-events:none;background:linear-gradient(90deg,#0000,#00ffff1a,#0000);position:absolute;inset:0}.cyberpunk-theme .table td{color:#e0e0e0;background:#1a1a1acc;border:1px solid #00ffff4d;transition:all .2s}.cyberpunk-theme .table tr:nth-child(2n) td{background:#262626cc}.cyberpunk-theme .table tr:hover td{color:#0ff;text-shadow:0 0 3px #0ff9;background:#00ffff1a;border-color:#0ff9}.cyberpunk-theme .table .total-row td{color:#fff;font-weight:var(--font-weight-bold);text-shadow:0 0 8px #0ffc;background:linear-gradient(135deg,#0ff3 0%,#ff008033 100%);border-color:#0ff}.cyberpunk-theme .table-wrapper.scrollable{border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0a0a0a4d;overflow:hidden;box-shadow:0 0 30px #0ff3}.cyberpunk-theme .list-item,.cyberpunk-theme .payment-item,.cyberpunk-theme .expense-item{color:#a3a3a3;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#1a1a1acc;border:1px solid #404040;box-shadow:0 0 5px #4040404d}.cyberpunk-theme .list-item:hover,.cyberpunk-theme .payment-item:hover,.cyberpunk-theme .expense-item:hover{color:#0ff;background:#262626e6;border-color:#0ff;box-shadow:0 0 10px #0ff6}.cyberpunk-theme .nav-link-active,.cyberpunk-theme .sidebar-button-active{color:#0ff;background:#0ff3;border:1px solid #0ff;box-shadow:0 0 10px #00ffff4d}.cyberpunk-theme .step-list li:before{background:linear-gradient(135deg,#0ff 0%,#ff073a 100%);border:1px solid #0ff;box-shadow:0 0 10px #00ffff80}.cyberpunk-theme .form-control{color:#e0e0e0;background:#1a1a1acc;border:1px solid #0ff;box-shadow:inset 0 0 10px #00ffff1a}.cyberpunk-theme .form-control:focus{color:#0ff;border-color:#ff0080;box-shadow:0 0 15px #ff00804d,inset 0 0 10px #0ff3}.cyberpunk-theme .btn{text-shadow:0 0 5px;border:1px solid #0ff;box-shadow:0 0 10px #0ff3}.cyberpunk-theme .btn-primary{color:#0a0a0a;background:linear-gradient(135deg,#0ff 0%,#0080ff 100%);border-color:#0ff}.cyberpunk-theme .btn-primary:hover{background:linear-gradient(135deg,#4dd0e1 0%,#3291ff 100%);box-shadow:0 0 20px #0ff6}.cyberpunk-theme .btn-fancy{align-items:center;gap:var(--spacing-2);padding:var(--spacing-3)var(--spacing-5);color:#0ff;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;text-shadow:0 0 5px #0ff9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all var(--transition-normal);background:#1a1a1acc;border:1px solid #0ff;text-decoration:none;display:inline-flex;position:relative;overflow:hidden;box-shadow:0 0 10px #00ffff4d}.cyberpunk-theme .btn-fancy:hover{text-shadow:0 0 8px #0ffc;background:#262626e6;transform:translateY(-1px);box-shadow:0 0 20px #00ffff80}.cyberpunk-theme .btn-fancy:focus{outline:none;box-shadow:0 0 0 3px #00ffff4d}.cyberpunk-theme .btn-secondary{color:#fff;background:linear-gradient(135deg,#ff0080 0%,#8e24aa 100%);border-color:#ff0080}.cyberpunk-theme .btn-secondary:hover{background:linear-gradient(135deg,#ff4081 0%,#ab47bc 100%);box-shadow:0 0 20px #ff008066}.cyberpunk-theme .banner-item{background:#1a1a1ae6;border:1px solid #0ff;box-shadow:0 0 15px #0ff3}.cyberpunk-theme .banner-item:hover{transform:translateY(-4px);box-shadow:0 0 25px #0ff6}.cyberpunk-theme .banner-item h3{color:#ff0080;text-shadow:0 0 5px #ff008099}.cyberpunk-theme .banner-item .value{color:#0ff;text-shadow:0 0 10px #0ffc}.cyberpunk-theme .no-items{color:#0ff;text-shadow:0 0 5px #00ffff80;background:#1a1a1acc;border:1px dashed #0ff}.cyberpunk-theme .demo-banner{color:#0ff;text-shadow:0 0 5px #00ffff80;background:linear-gradient(135deg,#ffff001a 0%,#00ffff1a 100%);border:1px solid #ff0;box-shadow:0 0 15px #ffff004d}.cyberpunk-theme .demo-banner strong{color:#ff0;text-shadow:0 0 8px #ff0c}.cyberpunk-theme .chart-legend{background:#1a1a1ae6;border:1px solid #0ff;box-shadow:0 0 15px #0ff3}.cyberpunk-theme .chart-legend p{color:#e0e0e0;text-shadow:0 0 3px #00ffff4d}.cyberpunk-theme .modal-wrapper{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#0a0a0acc}.cyberpunk-theme .error-container{border-color:var(--color-error);background-color:#ff073a1a;box-shadow:0 0 20px #ff073a4d}.cyberpunk-theme .error-container h2{color:var(--color-error);text-shadow:0 0 10px #ff073acc}.cyberpunk-theme .error-container p{color:#ff8a80}
*{box-sizing:border-box}a{color:var(--color-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{text-decoration:underline}ul{padding:0;list-style:none}button{cursor:pointer;font-family:inherit}input,select,textarea,button{font-family:var(--font-family-body)}
