@import url("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");body,html{margin:0;padding:0;font-family:var(--font-family-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-background);color:var(--color-text)}: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:#ffffff;--color-content-background:#ffffff;--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 rgba(0,0,0,0.05);--shadow-md:0 2px 4px rgba(0,0,0,0.1);--shadow-lg:0 4px 6px rgba(0,0,0,0.1);--shadow-xl:0 10px 15px rgba(0,0,0,0.1);--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-md: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-bold:600;--font-weight-extrabold:700;--spacing-0:0;--spacing-1:0.25rem;--spacing-2:0.5rem;--spacing-3:0.75rem;--spacing-4:1rem;--spacing-5:1.25rem;--spacing-6:1.5rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--radius-sm:0.125rem;--radius-md:0.25rem;--radius-lg:0.5rem;--radius-xl:0.75rem;--radius-full:9999px;--transition-fast:0.15s ease;--transition-normal:0.3s ease;--transition-slow:0.5s ease;--z-dropdown:100;--z-sticky:200;--z-modal:300;--z-toast:400;--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);--breakpoint-sm:640px;--breakpoint-md:768px;--breakpoint-lg:1024px;--breakpoint-xl:1280px;--text-color:#333;--input-bg:#fff;--border-color:#ddd}.dark-theme{--text-color:#ffffff;--input-bg:#2a2a2a;--border-color:#444}.expense-btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-decoration:none;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);outline:none;min-height:32px;gap:var(--spacing-1)}.expense-btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.expense-btn:focus{box-shadow:0 0 0 2px rgba(0,112,243,.3)}.expense-btn-primary{background-color:var(--color-primary);color:var(--color-white);border-color:var(--color-primary)}.expense-btn-primary:hover{background-color:var(--color-primary-dark);border-color:var(--color-primary-dark);color:var(--color-white);text-decoration:none;transform:translateY(-1px);box-shadow:0 4px 8px rgba(0,112,243,.15)}.expense-btn-secondary{background-color:var(--color-gray-200);color:var(--color-gray-800);border-color:var(--color-gray-300)}.expense-btn-secondary:hover{background-color:var(--color-gray-300);border-color:var(--color-gray-400);color:var(--color-gray-900);text-decoration:none;transform:translateY(-1px)}.expense-btn-success{border-color:var(--color-success)}.expense-btn-success,.expense-btn-success:hover{background-color:var(--color-success);color:var(--color-white)}.expense-btn-success:hover{filter:brightness(.9);text-decoration:none;transform:translateY(-1px)}.expense-btn-warning{border-color:var(--color-warning)}.expense-btn-warning,.expense-btn-warning:hover{background-color:var(--color-warning);color:var(--color-white)}.expense-btn-warning:hover{filter:brightness(.9);text-decoration:none;transform:translateY(-1px)}.expense-btn-danger{border-color:var(--color-error)}.expense-btn-danger,.expense-btn-danger:hover{background-color:var(--color-error);color:var(--color-white)}.expense-btn-danger:hover{filter:brightness(.9);text-decoration:none;transform:translateY(-1px)}.expense-btn-purple{background-color:#8854d0;color:var(--color-white);border-color:#8854d0}.expense-btn-purple:hover{background-color:#7048b8;border-color:#7048b8;color:var(--color-white);text-decoration:none;transform:translateY(-1px)}.expense-btn-small{padding:4px 12px;font-size:.85rem;min-height:28px}.expense-btn-large{padding:.75rem 1.5rem;font-size:1rem;min-height:44px}.expense-chart-toggle{background-color:var(--color-gray-200);border:1px solid var(--color-gray-300);border-radius:var(--radius-sm);padding:.5rem 1rem;font-size:.9rem;color:var(--color-gray-700);cursor:pointer;transition:all var(--transition-fast)}.expense-chart-toggle:hover{background-color:var(--color-gray-300);border-color:var(--color-gray-400);color:var(--color-gray-900);transform:translateY(-1px)}.expense-chart-toggle-active{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.expense-chart-toggle-active:hover{background-color:var(--color-primary-dark);border-color:var(--color-primary-dark)}.expense-year-badge{background-color:var(--color-gray-200);border:1px solid var(--color-gray-300);border-radius:var(--radius-sm);padding:.25rem .75rem;font-size:.875rem;color:var(--color-gray-700);cursor:pointer;transition:all var(--transition-fast);font-weight:var(--font-weight-medium)}.expense-year-badge:hover{background-color:var(--color-gray-300);border-color:var(--color-gray-400);color:var(--color-gray-900);transform:translateY(-1px)}.expense-year-badge-active{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.expense-year-badge-active:hover{background-color:var(--color-primary-dark);border-color:var(--color-primary-dark)}.expense-view-tab{background-color:transparent;border:none;border-bottom:3px solid transparent;padding:.75rem 1rem;font-size:.9rem;color:var(--color-gray-600);cursor:pointer;transition:all var(--transition-fast);font-weight:var(--font-weight-medium)}.expense-view-tab:hover{color:var(--color-gray-900);border-bottom-color:var(--color-gray-300)}.expense-view-tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:var(--font-weight-semibold)}.expense-view-tab-active:hover{color:var(--color-primary-dark);border-bottom-color:var(--color-primary-dark)}.expense-show-more-container{display:flex;justify-content:center;margin:1rem 0 2rem}.expense-show-more{background-color:var(--color-gray-200);border:1px solid var(--color-gray-300);border-radius:20px;padding:.5rem 1.5rem;font-size:.9rem;color:var(--color-gray-700);cursor:pointer;transition:all var(--transition-fast);font-weight:var(--font-weight-medium)}.expense-show-more:hover{background-color:var(--color-gray-300);border-color:var(--color-gray-400);color:var(--color-gray-900);transform:translateY(-1px);box-shadow:0 2px 4px rgba(0,0,0,.1)}.expense-button-group{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.expense-button-group .btn,.expense-button-group .expense-btn{margin-bottom:0}@media (max-width:768px){.expense-button-group{flex-direction:column}.expense-button-group .btn,.expense-button-group .expense-btn{width:100%;justify-content:center}.expense-year-badge{font-size:.8rem;padding:.2rem .6rem}.expense-view-tab{padding:.5rem .75rem;font-size:.85rem}}.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:#333333;--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:#333333;--color-input-border:#474747;--color-success:#4caf50;--color-success-light:rgba(76,175,80,0.2);--color-warning:#ff9800;--color-warning-light:rgba(255,152,0,0.2);--color-error:#f44336;--color-error-light:rgba(244,67,54,0.2);--color-info:#2196f3;--color-info-light:rgba(33,150,243,0.2);--shadow-sm:0 1px 2px rgba(0,0,0,0.2);--shadow-md:0 2px 4px rgba(0,0,0,0.3);--shadow-lg:0 4px 6px rgba(0,0,0,0.3);--shadow-xl:0 10px 15px rgba(0,0,0,0.4);--color-text-primary:#e8e8e8;--color-text-secondary:#a0a0a0;--color-sidebar-background:#2d2d2d;--color-nav-hover:#333333;--color-primary-hover:#1e88e5;--color-disabled:#5c5c5c;--color-tip-background:rgba(33,150,243,0.1);--color-tip-border:#2196f3;--color-tip-text:#64b5f6;--color-note-background:rgba(255,152,0,0.1);--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}.cyberpunk-theme{--color-primary:#00ffff;--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:#333333;--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:#ffffff;--color-text:#00ffff;--color-border:#ff0080;--color-input-border:#00ffff;--color-success:#39ff14;--color-success-light:rgba(57,255,20,0.2);--color-warning:#ffff00;--color-warning-light:rgba(255,255,0,0.2);--color-error:#ff073a;--color-error-light:rgba(255,7,58,0.2);--color-info:#00ffff;--color-info-light:rgba(0,255,255,0.2);--shadow-sm:0 0 4px rgba(0,255,255,0.3);--shadow-md:0 0 8px rgba(0,255,255,0.4);--shadow-lg:0 0 12px rgba(0,255,255,0.5);--shadow-xl:0 0 20px rgba(0,255,255,0.6);--color-text-primary:#00ffff;--color-text-secondary:#ff0080;--color-sidebar-background:#1a1a1a;--color-nav-hover:#262626;--color-primary-hover:#00b8d4;--color-disabled:#525252;--color-tip-background:rgba(0,255,255,0.1);--color-tip-border:#00ffff;--color-tip-text:#4dd0e1;--color-note-background:rgba(255,255,0,0.1);--color-note-border:#ffff00;--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 currentColor}.cyberpunk-theme h1,.cyberpunk-theme h2,.cyberpunk-theme h3,.cyberpunk-theme h4,.cyberpunk-theme h5,.cyberpunk-theme h6{color:#00ffff;text-shadow:0 0 10px rgba(0,255,255,.8);font-family:var(--font-family-heading);font-weight:var(--font-weight-heading)}*{box-sizing:border-box}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{text-decoration:underline}h1,h2,h3,h4,h5,h6{margin:0;color:var(--color-gray-900);font-weight:var(--font-weight-heading,var(--font-weight-bold));font-family:var(--font-family-heading)}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)}ul{list-style:none;padding:0}button{cursor:pointer;font-family:inherit}button,input,select,textarea{font-family:var(--font-family-body)}.formGroupInline{display:flex;align-items:center;gap:var(--spacing-4)}.formGroupInline label{flex:1 1}.formGroupInline input{width:100%}.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);transform:translateY(-4px);border-color:var(--color-primary)}.card-primary{border-left:4px solid var(--color-primary);background-color:rgba(0,112,243,.02)}.card-success{border-left:4px solid var(--color-success);background-color:rgba(76,175,80,.02)}.card-warning{border-left:4px solid var(--color-warning);background-color:rgba(255,152,0,.02)}.card-error{border-left:4px solid var(--color-error);background-color:rgba(244,67,54,.02)}.card-info{border-left:4px solid var(--color-info);background-color:rgba(33,150,243,.02)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-3);border-bottom:1px solid var(--color-border)}.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 1}.card-text{color:var(--color-gray-700);line-height:1.5;margin-bottom:var(--spacing-4)}.card-footer{margin-top:var(--spacing-4);padding-top:var(--spacing-3);border-top:1px solid var(--color-border);justify-content:space-between}.card-actions,.card-footer{display:flex;align-items:center}.card-actions{gap:var(--spacing-2)}.profile-card,.summary-card{text-align:center}.summary-card{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{display:grid;grid-gap:var(--spacing-6);gap:var(--spacing-6);margin-bottom:var(--spacing-6)}.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{display:inline-block;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}.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:transparent;border:1px solid}.badge-light{background-color:var(--color-gray-100);color:var(--color-gray-800)}.badge-dark{background-color:var(--color-gray-800)}.badge-dark,.tax-badge{color:var(--color-white)}.tax-badge{background-color:var(--color-success)}.cc-badge{background-color:var(--color-info);color:var(--color-white)}.found-badge{background-color:#c6f6d5;color:#22543d}.missing-badge{background-color:#fed7d7;color:#822727}.addon-badge{background-color:var(--color-info);color:var(--color-white);text-transform:capitalize}.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-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);margin-bottom:var(--spacing-6);border-bottom:2px solid var(--color-border);padding-bottom:var(--spacing-3)}.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-header{margin-bottom:var(--spacing-6);gap:var(--spacing-4)}.section-header h1,.section-header h2{margin:0}.section-actions{display:flex;gap:var(--spacing-3);align-items:center}.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;margin:0 auto;padding:var(--spacing-6)}.page-container-wide{max-width:1400px}.page-container-narrow{max-width:800px}.page-container-full{max-width:none;width:100%}.section-grid{display:grid;grid-gap:var(--spacing-6);gap:var(--spacing-6);margin-bottom:var(--spacing-8)}.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))}.import-button{background-color:#4caf50;color:white;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:500;cursor:pointer;transition:background-color .2s,transform .1s;display:inline-block;font-size:1rem;box-shadow:0 2px 4px rgba(0,0,0,.1)}.import-button:hover{background-color:#3d8b40;transform:translateY(-1px);box-shadow:0 4px 8px rgba(0,0,0,.15)}.section-header{justify-content:space-between;margin-bottom:1rem}.section-header,.year-badges{display:flex;align-items:center;flex-wrap:wrap}.year-badges{gap:.5rem}.year-badge{background-color:#f0f0f0;border:1px solid #ddd;border-radius:1rem;padding:.25rem .75rem;font-size:.85rem;cursor:pointer;transition:all .2s ease}.year-badge:hover{background-color:#e6e6e6}.active-year-badge{background-color:#0070f3;color:white;border-color:#0070f3}.clear-year-filters{background-color:#f44336;color:white;border:none;border-radius:50%;width:24px;height:24px;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;margin-left:5px}.clear-year-filters:hover{background-color:#d32f2f}.delete-mode{background-color:#fff3cd;border:1px solid #ffecb5;color:#856404;padding:10px 15px;border-radius:4px;margin-bottom:15px}.delete-mode p{margin:0;display:flex;align-items:center;gap:8px}.filter-controls{margin-bottom:20px;display:flex;flex-direction:column;gap:10px}.filter-toggles{display:flex;gap:20px;margin-bottom:10px}.filter-toggle{display:flex;align-items:center;gap:8px}.filter-toggle input{margin:0}.filter-toggle label{color:var(--color-text-primary)}.filter-options{display:flex;gap:10px}.filter-select{padding:8px;border-radius:4px;border:1px solid var(--color-input-border);background-color:var(--color-white);color:var(--color-text-primary)}.empty-state{text-align:center;padding:30px;background-color:var(--color-gray-100);border-radius:8px;border:1px dashed var(--color-border)}.empty-state p{color:var(--color-text-secondary);margin-bottom:15px}.payment-list{margin:0 0 30px}.payment-item{padding:24px;border-radius:16px;margin-bottom:24px;background:linear-gradient(135deg,var(--color-content-background),rgba(255,255,255,.8));box-shadow:0 4px 12px rgba(0,0,0,.08),0 2px 4px rgba(0,0,0,.04);position:relative;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.payment-item,.payment-item:before{transition:all .4s cubic-bezier(.4,0,.2,1)}.payment-item:before{content:"";position:absolute;top:0;left:0;width:5px;height:100%;background:linear-gradient(45deg,#0070f3,#3291ff,#00d4ff);background-size:200% 200%;animation:gradientShift 3s ease infinite;border-radius:0 3px 3px 0}@keyframes gradientShift{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.payment-item:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 8px 32px rgba(0,112,243,.15),0 4px 12px rgba(0,0,0,.1);border-color:var(--color-primary);background:linear-gradient(135deg,rgba(255,255,255,.95),rgba(0,112,243,.02))}.payment-item:hover:before{width:8px;box-shadow:0 0 20px rgba(0,112,243,.4)}.payment-info{display:flex;flex-direction:column;gap:8px;width:100%}.payment-main{display:flex;justify-content:space-between;align-items:center;gap:16px}.payment-source{font-size:1.1rem;color:var(--color-text-primary);font-weight:600;line-height:1.3;letter-spacing:-.02em}.payment-date{font-size:.9rem}.payment-date,.payment-invoice{color:var(--color-text-secondary);font-weight:500}.payment-invoice{font-size:.85rem;background:var(--color-gray-100);padding:4px 8px;border-radius:4px}.payment-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}.expense-header{margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid var(--color-gray-100);position:relative}.expense-header:after{content:"";position:absolute;bottom:-2px;left:0;width:60px;height:2px;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-light));border-radius:1px}.expense-title{gap:6px;flex:1 1}.expense-title strong{font-size:1.3rem;font-weight:600;line-height:1.3;letter-spacing:-.02em;margin-bottom:4px}.payment-amount{font-weight:700;color:#197837;font-size:1.2rem;padding:8px 12px;background:linear-gradient(135deg,rgba(25,120,55,.12),rgba(25,120,55,.08));border:1px solid rgba(25,120,55,.2);border-radius:8px;display:inline-block;width:-moz-fit-content;width:fit-content;box-shadow:0 2px 4px rgba(25,120,55,.1);transition:all .3s ease}.payment-amount:hover{transform:translateY(-1px);box-shadow:0 4px 8px rgba(25,120,55,.2)}.expense-actions{gap:10px;align-items:flex-start}.edit-button{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #dee2e6;border-radius:8px;padding:8px 16px;font-size:.85rem;color:#495057;cursor:pointer;transition:all .2s ease;font-weight:500;box-shadow:0 1px 3px rgba(0,0,0,.1)}.edit-button:hover{background:linear-gradient(135deg,#e9ecef,#dee2e6);border-color:#adb5bd;transform:translateY(-1px);box-shadow:0 2px 6px rgba(0,0,0,.15);color:#343a40}.delete-button{background:linear-gradient(135deg,#f8d7da,#f5c2c7);border:1px solid #f5c2c7;color:#721c24;border-radius:8px;padding:8px 16px;font-size:.85rem;cursor:pointer;transition:all .2s ease;font-weight:500;box-shadow:0 1px 3px rgba(0,0,0,.1)}.delete-button:hover{background:linear-gradient(135deg,#f5c2c7,#ea868f);border-color:#dc3545;transform:translateY(-1px);box-shadow:0 2px 6px rgba(220,53,69,.2);color:#580a0e}.expense-description{margin-bottom:14px;color:var(--color-text-secondary);font-size:.96rem;line-height:1.6;padding:12px 16px;background:var(--color-gray-50);border-radius:8px;border-left:3px solid var(--color-gray-300)}.expense-details{gap:16px;font-size:.88rem;margin-top:8px;padding:12px 0}.expense-date{display:flex;align-items:center;font-weight:500;color:var(--color-text)}.actionButton{background-color:#0070f3;color:white;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:500;cursor:pointer;transition:background-color .2s,transform .1s;display:inline-block;font-size:1rem;box-shadow:0 2px 4px rgba(0,0,0,.1);margin-bottom:1.5rem}.actionButton:hover{background-color:#005bb5;transform:translateY(-1px);box-shadow:0 4px 8px rgba(0,0,0,.15)}.tax-badge{background:linear-gradient(135deg,#4caf50,#45a049);color:white;padding:6px 12px;border-radius:16px;font-size:.75rem;font-weight:600;box-shadow:0 2px 4px rgba(76,175,80,.3);transition:all .2s ease}.tax-badge:hover{transform:translateY(-1px);box-shadow:0 4px 8px rgba(76,175,80,.4)}.cc-badge{background:linear-gradient(135deg,#2196f3,#1976d2);color:white;padding:6px 12px;border-radius:16px;font-size:.75rem;font-weight:600;box-shadow:0 2px 4px rgba(33,150,243,.3);transition:all .2s ease}.cc-badge:hover{transform:translateY(-1px);box-shadow:0 4px 8px rgba(33,150,243,.4)}.attachment-link{text-decoration:none}.attachment-badge{display:inline-flex;align-items:center;background:linear-gradient(135deg,#ebf8ff,#e6f6ff);color:#3182ce;padding:6px 12px;border-radius:16px;font-size:.75rem;font-weight:600;margin-left:8px;border:1px solid #bee3f8;transition:all .2s ease;box-shadow:0 2px 4px rgba(49,130,206,.1)}.attachment-badge:hover{transform:translateY(-1px);box-shadow:0 4px 8px rgba(49,130,206,.2);background:linear-gradient(135deg,#e6f6ff,#dbeafe)}.show-more-container{display:flex;justify-content:center;margin:1rem 0 2rem}.show-more-button{background-color:#f0f0f0;border:1px solid #ddd;border-radius:20px;padding:.5rem 1.5rem;font-size:.9rem;color:#555;cursor:pointer;transition:all .2s ease}.show-more-button:hover{background-color:#e0e0e0;border-color:#ccc;transform:translateY(-1px)}.statistics{display:flex;flex-direction:row;justify-content:space-between;flex-wrap:wrap;margin:2rem 0}.stat-box{background-color:var(--color-content-background);padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px rgba(0,0,0,.1)}.stat-box h3{margin-top:0;color:#333;font-size:1rem}.stat-box p{font-size:1.5rem;font-weight:700;color:#0070f3;margin:.5rem 0 0}.chart-container{background-color:var(--color-content-background);padding:1rem;border-radius:8px;box-shadow:0 1px 3px rgba(0,0,0,.1);margin-top:1rem}@media (max-width:768px){.button-group{flex-direction:column;width:100%}.action-button,.import-button{width:100%;margin-bottom:10px}.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{margin-top:10px;width:100%;justify-content:flex-end;flex-direction:column;gap:5px}.year-badges{margin-top:10px;width:100%;justify-content:flex-start}}.table{width:100%;border-collapse:collapse;background-color:var(--color-white);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-4)}.table td,.table th{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 td,.table-compact th{padding:var(--spacing-2) var(--spacing-3)}.table-spacious td,.table-spacious th{padding:var(--spacing-4) var(--spacing-6)}.table-borderless{box-shadow:none}.table-borderless td,.table-borderless th{border:none}.table-striped tr:nth-child(2n){background-color:var(--color-gray-50)}.table-hoverable tr:hover{background-color:var(--color-gray-100);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.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);overflow:hidden;margin-bottom:var(--spacing-6)}.table-wrapper{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;max-height:600px;overflow-y:auto}.table-wrapper.scrollable{max-height:400px;border:1px solid var(--color-border);border-radius:var(--radius-md)}.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);position:-webkit-sticky;position:sticky;top:0;z-index:10}.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);position:-webkit-sticky;position:sticky;top:0;z-index:10;box-shadow:0 1px 0 var(--color-border)}.preview-table{font-size:var(--font-size-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;max-height:300px;margin-bottom:var(--spacing-4)}.preview-table th{background-color:var(--color-gray-100);position:-webkit-sticky;position:sticky;top:0;z-index:10;box-shadow:0 1px 0 var(--color-border)}.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 td,.table th{padding:var(--spacing-2) var(--spacing-3)}.table-wrapper{margin-bottom:var(--spacing-4)}.preview-table,.report-table,.results-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 td,.table th{padding:var(--spacing-2)}.table-wrapper{border-radius:var(--radius-sm)}.statistics{flex-direction:column}}.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)}.cyberpunk-theme .table{background:rgba(10,10,10,.9);border:1px solid #00ffff;box-shadow:0 0 15px rgba(0,255,255,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.cyberpunk-theme .table th{background:linear-gradient(135deg,#1a1a1a,#262626);color:#00ffff;border:1px solid #00ffff;text-shadow:0 0 5px rgba(0,255,255,.8);font-weight:var(--font-weight-bold);position:relative}.cyberpunk-theme .table th:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(0,255,255,.1),transparent);pointer-events:none}.cyberpunk-theme .table td{background:rgba(26,26,26,.8);color:#e0e0e0;border:1px solid rgba(0,255,255,.3);transition:all .2s ease}.cyberpunk-theme .table tr:nth-child(2n) td{background:rgba(38,38,38,.8)}.cyberpunk-theme .table tr:hover td{background:rgba(0,255,255,.1);color:#00ffff;text-shadow:0 0 3px rgba(0,255,255,.6);border-color:rgba(0,255,255,.6)}.cyberpunk-theme .table .total-row td{background:linear-gradient(135deg,rgba(0,255,255,.2),rgba(255,0,128,.2));color:#ffffff;font-weight:var(--font-weight-bold);text-shadow:0 0 8px rgba(0,255,255,.8);border-color:#00ffff}.cyberpunk-theme .table-wrapper.scrollable{border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 0 30px rgba(0,255,255,.2);background:rgba(10,10,10,.3);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.list{margin:0}.list,.list-spaced{list-style:none;padding:0}.list-spaced{margin:var(--spacing-4) 0}.list-compact{list-style:none;padding:0;margin:var(--spacing-2) 0}.list-ordered{list-style-type:decimal}.list-bulleted,.list-ordered{padding-left:var(--spacing-6);margin:var(--spacing-4) 0}.list-bulleted{list-style-type:disc}.list-hoverable,.list-interactive,.list-unstyled{list-style:none;padding:0;margin:0}.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);border-radius:var(--radius-sm);border:1px solid var(--color-border);transition:var(--transition-fast)}.list-item-compact,.list-item-spacious{background-color:var(--color-content-background)}.list-item-spacious{padding:var(--spacing-5);margin-bottom:var(--spacing-4);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);background-color:transparent;border-radius:0;border:none;border-bottom:1px solid var(--color-border);transition:var(--transition-fast)}.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-elevated:hover,.list-item-spacious:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.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{list-style:none;padding:0;margin:var(--spacing-4) 0}.payment-item{padding:16px;border:1px solid var(--color-border);border-radius:8px;margin-bottom:16px;background-color:var(--color-content-background);box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease}.payment-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.payment-item small{color:var(--color-text-secondary);margin-top:.25rem}.payment-details{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}.expense-list{list-style:none;padding:0;margin:var(--spacing-4) 0}.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{display:flex;justify-content:space-between;margin-bottom:var(--spacing-1)}.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{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-2)}.expense-title{display:flex;flex-direction:column;gap:var(--spacing-1)}.expense-title strong{font-size:var(--font-size-lg);color:var(--color-text-primary)}.expense-description{margin-bottom:10px;color:#555;font-size:.95rem}.expense-details{display:flex;flex-wrap:wrap;gap:var(--spacing-3);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.expense-actions{display:flex;gap:var(--spacing-2);margin-top:var(--spacing-2)}.results-list{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;margin:var(--spacing-5) 0;max-height:400px;overflow-y:auto}.results-list-large{max-height:600px}.results-list-compact{max-height:300px}.nav-list{list-style-type:none;padding:0;margin:0}.nav-item{margin-bottom:var(--spacing-3)}.nav-link{display:block;padding:var(--spacing-3);border-radius:var(--radius-md);transition:var(--transition-fast);cursor:pointer}.nav-link,.nav-link:hover{text-decoration:none;color:var(--color-text-primary)}.nav-link:hover{background-color:var(--color-nav-hover)}.nav-link-active{background-color:var(--color-primary);color:var(--color-white);font-weight:var(--font-weight-medium)}.sidebar-list{list-style:none;padding:0;margin:0}.sidebar-button{width:100%;text-align:left;padding:var(--spacing-3);margin-bottom:var(--spacing-2);background:none;border:none;border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-sm);cursor:pointer;transition:var(--transition-fast)}.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{list-style-type:none;counter-reset:steps;padding-left:var(--spacing-3);margin:var(--spacing-4) 0}.step-list li{position:relative;margin-bottom:var(--spacing-4);padding-left:var(--spacing-9);counter-increment:steps}.step-list li:before{content:counter(steps);position:absolute;left:0;top:0;width:25px;height:25px;background-color:var(--color-primary);color:var(--color-white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.credential-list{list-style:none;padding:0;margin:var(--spacing-4) 0}.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)}@media (max-width:768px){.payment-item{padding:var(--spacing-3)}.payment-info,.payment-main{flex-direction:column;align-items:flex-start;gap:var(--spacing-2)}.expense-details,.payment-details{margin-top:var(--spacing-3);width:100%}.expense-header{flex-direction:column;align-items:flex-start}.expense-actions{margin-top:var(--spacing-3);width:100%;justify-content:flex-end;flex-direction:column;gap:var(--spacing-1)}.nav-link,.sidebar-button{padding:var(--spacing-2)}}@media (max-width:480px){.credential-item,.expense-item,.list-item-elevated,.list-item-spacious,.payment-item{padding:var(--spacing-2)}.expense-title strong,.payment-title strong{font-size:var(--font-size-base)}.step-list{padding-left:var(--spacing-2)}.step-list li{padding-left:var(--spacing-6)}.step-list li:before{width:20px;height:20px;font-size:var(--font-size-xs)}}.dark-theme .credential-item,.dark-theme .expense-item,.dark-theme .list-item,.dark-theme .payment-item{background-color:var(--color-content-background);border-color:var(--color-border)}.dark-theme .expense-item:hover,.dark-theme .list-item:hover,.dark-theme .nav-link:hover,.dark-theme .payment-item:hover,.dark-theme .sidebar-button:hover{background-color:var(--color-nav-hover)}.cyberpunk-theme .expense-item,.cyberpunk-theme .list-item,.cyberpunk-theme .payment-item{background:rgba(26,26,26,.8);border:1px solid #404040;color:#a3a3a3;box-shadow:0 0 5px rgba(64,64,64,.3);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.cyberpunk-theme .expense-item:hover,.cyberpunk-theme .list-item:hover,.cyberpunk-theme .payment-item:hover{background:rgba(38,38,38,.9);border-color:#00ffff;color:#00ffff;box-shadow:0 0 10px rgba(0,255,255,.4)}.cyberpunk-theme .nav-link-active,.cyberpunk-theme .sidebar-button-active{background:rgba(0,255,255,.2);border:1px solid #00ffff;color:#00ffff;box-shadow:0 0 10px rgba(0,255,255,.3)}.cyberpunk-theme .step-list li:before{background:linear-gradient(135deg,#00ffff,#ff073a);border:1px solid #00ffff;box-shadow:0 0 10px rgba(0,255,255,.5)}.form{flex-direction:column;margin:0;padding:var(--spacing-6);overflow-y:scroll}.form,.form-horizontal{display:flex;gap:var(--spacing-4)}.form-horizontal{flex-direction:row;flex-wrap:wrap}.form-inline{display:flex;flex-direction:row;gap:var(--spacing-3);align-items:center}.form-group{display:flex;flex-direction:column;gap:var(--spacing-2);margin-bottom:var(--spacing-4)}.form-group:last-child{margin-bottom:0}.form-group 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{display:flex;flex-direction:row;align-items:center;gap:var(--spacing-4)}.form-group-horizontal label{flex:0 0 auto;margin-bottom:0;min-width:120px}.form-control{padding:var(--spacing-3);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-size-md);font-family:var(--font-family-body);background-color:var(--input-bg);color:var(--text-color);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-control:focus{outline:none;border-color:var(--color-input-focus);box-shadow:0 0 0 3px rgba(0,112,243,.1)}.form-control:disabled{background-color:var(--color-gray-100);color:var(--color-gray-500);cursor:not-allowed}.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)}textarea.form-control{resize:vertical;min-height:100px}select.form-control{cursor:pointer}input[type=file].form-control{padding:var(--spacing-2)}.form-control.error{border-color:var(--color-error)}.form-control.error:focus{box-shadow:0 0 0 3px rgba(229,62,62,.1)}.form-error{color:var(--color-error)}.form-error,.form-help{font-size:var(--font-size-sm);margin-top:var(--spacing-1)}.form-help{color:var(--color-text-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;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);text-decoration:none;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);outline:none;min-height:44px;gap:var(--spacing-2)}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn:focus{box-shadow:0 0 0 3px rgba(0,112,243,.3)}.btn-fancy,.btn-primary{background-color:var(--color-primary);color:var(--color-white);border-color:var(--color-primary)}.btn-fancy:hover,.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{border-color:var(--color-success)}.btn-success,.btn-success:hover{background-color:var(--color-success);color:var(--color-white)}.btn-success:hover{filter:brightness(.9);text-decoration:none}.btn-warning{border-color:var(--color-warning)}.btn-warning,.btn-warning:hover{background-color:var(--color-warning);color:var(--color-white)}.btn-warning:hover{filter:brightness(.9);text-decoration:none}.btn-danger{border-color:var(--color-error)}.btn-danger,.btn-danger:hover{background-color:var(--color-error);color:var(--color-white)}.btn-danger:hover{filter:brightness(.9);text-decoration:none}.btn-info{border-color:var(--color-info)}.btn-info,.btn-info:hover{background-color:var(--color-info);color:var(--color-white)}.btn-info:hover{filter:brightness(.9);text-decoration:none}.btn-outline-primary{background-color:transparent;color:var(--color-primary);border-color:var(--color-primary)}.btn-outline-primary:hover{background-color:var(--color-primary);color:var(--color-white);text-decoration:none}.btn-outline-secondary{background-color:transparent;color:var(--color-gray-700);border-color:var(--color-gray-400)}.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-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}.button-group{display:flex;gap:10px;margin-bottom:20px}.button-group-vertical{display:flex;flex-direction:column;gap:var(--spacing-2)}.button-group-connected{display:flex;gap:0}.button-group-connected .btn{border-radius:0}.button-group-connected .btn:first-child{border-top-left-radius:var(--radius-md);border-bottom-left-radius:var(--radius-md)}.button-group-connected .btn:last-child{border-top-right-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md)}.button-group-connected .btn:not(:last-child){border-right:none}.summary-banner{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:var(--spacing-4);gap:var(--spacing-4);margin-bottom:var(--spacing-6);margin-top:var(--spacing-6)}.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{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.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);font-style:italic;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}.dark-theme .form-control{background-color:var(--color-gray-800);border-color:var(--color-gray-600);color:black}.dark-theme .form-control:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(50,145,255,.1)}.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)}.cyberpunk-theme .form-control{background:rgba(26,26,26,.8);border:1px solid #00ffff;color:#e0e0e0;box-shadow:inset 0 0 10px rgba(0,255,255,.1)}.cyberpunk-theme .form-control:focus{border-color:#ff0080;box-shadow:0 0 15px rgba(255,0,128,.3),inset 0 0 10px rgba(0,255,255,.2);color:#00ffff}.cyberpunk-theme .btn{border:1px solid #00ffff;text-shadow:0 0 5px currentColor;box-shadow:0 0 10px rgba(0,255,255,.2)}.cyberpunk-theme .btn-primary{background:linear-gradient(135deg,#00ffff,#0080ff);border-color:#00ffff;color:#0a0a0a}.cyberpunk-theme .btn-primary:hover{background:linear-gradient(135deg,#4dd0e1,#3291ff);box-shadow:0 0 20px rgba(0,255,255,.4)}.cyberpunk-theme .btn-fancy{display:inline-flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-5);background:rgba(26,26,26,.8);color:#00ffff;border:1px solid #00ffff;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;text-decoration:none;box-shadow:0 0 10px rgba(0,255,255,.3);text-shadow:0 0 5px rgba(0,255,255,.6);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow:hidden;transition:all var(--transition-normal)}.cyberpunk-theme .btn-fancy:hover{background:rgba(38,38,38,.9);box-shadow:0 0 20px rgba(0,255,255,.5);text-shadow:0 0 8px rgba(0,255,255,.8);transform:translateY(-1px)}.cyberpunk-theme .btn-fancy:focus{outline:none;box-shadow:0 0 0 3px rgba(0,255,255,.3)}.cyberpunk-theme .btn-secondary{background:linear-gradient(135deg,#ff0080,#8e24aa);border-color:#ff0080;color:#ffffff}.cyberpunk-theme .btn-secondary:hover{background:linear-gradient(135deg,#ff4081,#ab47bc);box-shadow:0 0 20px rgba(255,0,128,.4)}.cyberpunk-theme .banner-item{background:rgba(26,26,26,.9);border:1px solid #00ffff;box-shadow:0 0 15px rgba(0,255,255,.2)}.cyberpunk-theme .banner-item:hover{box-shadow:0 0 25px rgba(0,255,255,.4);transform:translateY(-4px)}.cyberpunk-theme .banner-item h3{color:#ff0080;text-shadow:0 0 5px rgba(255,0,128,.6)}.cyberpunk-theme .banner-item .value{color:#00ffff;text-shadow:0 0 10px rgba(0,255,255,.8)}.cyberpunk-theme .no-items{background:rgba(26,26,26,.8);border:1px dashed #00ffff;color:#00ffff;text-shadow:0 0 5px rgba(0,255,255,.5)}.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);display:flex;align-items:center;gap:var(--spacing-2)}.chart-average{color:rgba(75,192,192,1);font-weight:var(--font-weight-bold);font-size:var(--font-size-lg)}.chart-line{font-size:var(--font-size-sm);letter-spacing:1px}.chart-average-exp,.chart-line{color:rgba(255,99,132,1);font-weight:var(--font-weight-bold)}.chart-average-exp{font-size:var(--font-size-lg)}.chart-expense-line{color:rgba(54,162,235,1)}.chart-2024-line,.chart-expense-line{font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);letter-spacing:1px}.chart-2024-line{color:rgba(75,192,192,1)}.modal-wrapper{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--spacing-4)}.modal-wrapper>*{max-width:90vw;max-height:90vh;overflow-y:auto}.dark-theme .demo-banner{background:linear-gradient(135deg,rgba(255,152,0,.2),rgba(33,150,243,.2));border-color:var(--color-warning);color:var(--color-text)}.dark-theme .chart-legend{background-color:var(--color-gray-800);border-color:var(--color-gray-700)}.cyberpunk-theme .demo-banner{background:linear-gradient(135deg,rgba(255,255,0,.1),rgba(0,255,255,.1));border:1px solid #ffff00;box-shadow:0 0 15px rgba(255,255,0,.3);color:#00ffff;text-shadow:0 0 5px rgba(0,255,255,.5)}.cyberpunk-theme .demo-banner strong{color:#ffff00;text-shadow:0 0 8px rgba(255,255,0,.8)}.cyberpunk-theme .chart-legend{background:rgba(26,26,26,.9);border:1px solid #00ffff;box-shadow:0 0 15px rgba(0,255,255,.2)}.cyberpunk-theme .chart-legend p{color:#e0e0e0;text-shadow:0 0 3px rgba(0,255,255,.3)}.cyberpunk-theme .modal-wrapper{background-color:rgba(10,10,10,.8);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@media (prefers-color-scheme:dark){:root{--text-color:#ffffff;--input-bg:#2a2a2a;--border-color:#444}}