:root{--color-primary:#6366f1;--color-success:#548164;--color-info:#487ca5;--color-error:#c4554d;--color-warning:#d97706;--color-background:#fff;--color-surface:#fafafa;--color-text-primary:#373530;--color-text-secondary:#787774;--color-border:#d1d5db;--color-hover:#eef2ff;--color-divider:#e5e7eb;--color-inactive:#9ca3af;--spacing-4:4px;--spacing-8:8px;--spacing-12:12px;--spacing-16:16px;--spacing-20:20px;--spacing-24:24px;--radius-standard:16px;--radius-small:12px}*{box-sizing:border-box;font-family:inherit;margin:0;padding:0}body{-webkit-overflow-scrolling:touch;background:#fafafa;background:var(--color-surface);color:#373530;color:var(--color-text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;min-height:100vh;overscroll-behavior:none;touch-action:manipulation}.container{margin:0 auto;max-width:1200px;padding:20px}.header{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-divider);border-radius:16px;border-radius:var(--radius-standard);box-shadow:0 1px 3px #0000001a;color:#373530;color:var(--color-text-primary);margin-bottom:2rem;padding:2rem}.header:before{background:radial-gradient(circle,#ffffff1a 0,#0000 70%);content:"";height:100%;pointer-events:none;position:absolute;right:-50%;top:-50%;width:100%}.card{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--color-divider);border-radius:16px;border-radius:var(--radius-standard);padding:1.5rem}.card,.form-group{margin-bottom:1rem}.form-group label{color:#373530;color:var(--color-text-primary);display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{background:#fff;background:var(--color-background);border:1px solid #d1d5db;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--radius-small);color:#373530;color:var(--color-text-primary);font-family:inherit;font-size:1rem;padding:.75rem;transition:all .2s ease;width:100%}select{-webkit-appearance:none!important;appearance:none!important;background-color:#fff!important;background-color:var(--color-background)!important;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%23787774' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E")!important;background-position:right .5rem center!important;background-repeat:no-repeat!important;background-size:1.5em 1.5em!important;border:1px solid #d1d5db!important;border:1px solid var(--color-border)!important;border-radius:12px!important;border-radius:var(--radius-small)!important;color:#373530!important;color:var(--color-text-primary)!important;cursor:pointer!important;font-family:inherit!important;font-size:1rem!important;padding:.75rem!important;transition:all .2s ease!important}select:hover{border-color:#9ca3af!important;border-color:var(--color-inactive)!important}select:focus{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236366F1' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E")!important;border-color:#6366f1!important;border-color:var(--color-primary)!important;box-shadow:0 0 0 3px #6366f11a!important;outline:none!important}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#6366f1;border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f11a;outline:none}.btn{background:#6366f1;background:var(--color-primary);border:none;border-radius:12px;border-radius:var(--radius-small);color:#fff;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;margin-right:.5rem;padding:.75rem 1rem;transition:all .2s ease}.btn:hover{background:#5856eb}.btn:active{transform:translateY(0)}.btn-active{background:#373530;background:var(--color-text-primary)}.btn-danger,.btn-danger:hover{background:#c4554d}.btn-danger:hover{background:var(--color-error)}.transaction-list{max-height:400px;overflow-y:auto}.transaction-item{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--color-divider);border-radius:12px;margin-bottom:.5rem;padding:1rem}.transaction-item:hover{background:#fafafa;box-shadow:0 1px 3px #0000001a}.transaction-item:last-child{border-bottom:none}.income{color:#548164;color:var(--color-success);font-weight:500}.expense{color:#c4554d;color:var(--color-error);font-weight:500}.ai-analysis{background:#fafafa;background:var(--color-surface);border:1px solid #e5e7eb;border:1px solid var(--color-divider);border-radius:12px;border-radius:var(--radius-small);margin-top:1rem;padding:1.5rem;white-space:pre-line}*{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}input,select,textarea{-webkit-user-select:text;user-select:text}button{-webkit-tap-highlight-color:rgba(0,0,0,.1);transition:all .2s ease}button:active{opacity:.8;transform:scale(.95)}@media (max-width:768px){.container{padding:.5rem}nav{-webkit-overflow-scrolling:touch;-ms-overflow-style:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border-radius:0 0 20px 20px;box-shadow:0 1px 3px #0000001a;display:flex;overflow-x:auto;padding:1rem 0;position:-webkit-sticky;position:sticky;scrollbar-width:none;top:0;z-index:100}nav::-webkit-scrollbar{display:none}nav button{font-size:.85rem;margin-right:.75rem;min-width:90px;padding:.75rem 1rem;white-space:nowrap}.card,nav button{border-radius:20px}.card{box-shadow:0 1px 3px #0000001a;margin-bottom:1rem;padding:1.5rem}.form-group input,.form-group select,.form-group textarea{font-size:16px;padding:.75rem}.transaction-item{background:#ffffffb3;border:1px solid #e5e7eb;border:1px solid var(--color-divider);border-radius:15px;margin-bottom:.75rem;padding:1.25rem}}@media (display-mode:standalone){body{padding-bottom:env(safe-area-inset-bottom);padding-top:env(safe-area-inset-top)}.mobile-header{padding-top:calc(1rem + env(safe-area-inset-top))}.main-content{padding-top:calc(70px + env(safe-area-inset-top))}}.loading-spinner{border:2px solid #fafafa;border-top:2px solid #6366f1;border:2px solid var(--color-surface);display:inline-block;margin-right:.5rem}@media (max-width:480px){.header h1{font-size:1.5rem}.btn,.header p{font-size:.9rem}.btn{padding:.6rem 1rem}}.swipe-container{transition:transform .3s ease}.chart-selector,.month-selector{-webkit-appearance:none!important;appearance:none!important;background:#fff!important;background:var(--color-background)!important;border:1px solid #d1d5db!important;border:1px solid var(--color-border)!important;border-radius:12px!important;border-radius:var(--radius-small)!important;color:#373530!important;color:var(--color-text-primary)!important;cursor:pointer!important;font-family:inherit!important;font-size:.875rem!important;min-width:140px!important;padding:.75rem 1rem!important;transition:all .2s ease!important}.chart-selector:hover,.month-selector:hover{border-color:#9ca3af!important;border-color:var(--color-inactive)!important}.chart-selector:focus,.month-selector:focus{border-color:#6366f1!important;border-color:var(--color-primary)!important;box-shadow:0 0 0 3px #6366f11a!important;outline:none!important}.chart-selector{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%23787774' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E")!important;background-position:right .5rem center!important;background-repeat:no-repeat!important;background-size:1.5em 1.5em!important;padding-right:2.5rem!important}.chart-selector:focus{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236366F1' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E")!important}.app-layout{background:#fafafa;background:var(--color-surface)}.sidebar{background:#fff;background:var(--color-background);border-right:1px solid #e5e7eb;border-right:1px solid var(--color-divider);z-index:1000}.sidebar-header{border-bottom:1px solid #fafafa;border-bottom:1px solid var(--color-surface);padding:2rem 1.5rem 1rem}.sidebar-header h1{color:#373530;font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.sidebar-header p{color:#787774;font-size:.875rem}.sidebar-nav{padding:1rem 0}.nav-section{margin-bottom:2rem}.nav-section h3{color:#9ca3af;color:var(--color-inactive);font-size:.75rem;letter-spacing:.05em;margin:0;padding:0 1.5rem .75rem}.nav-item{border-radius:0;color:#787774;color:var(--color-text-secondary);font-size:.875rem;margin:0;padding:.75rem 1.5rem}.nav-item:hover{background:#fafafa;background:var(--color-surface);color:#373530;color:var(--color-text-primary)}.nav-item.active{background:#eef2ff;border-right:3px solid #6366f1;border-right:3px solid var(--color-primary);color:#6366f1}.sidebar-footer{border-top:1px solid #fafafa;border-top:1px solid var(--color-surface);display:flex;flex-direction:column;gap:.5rem;padding:1rem 1.5rem}.install-btn{border:none;border-radius:12px;border-radius:var(--radius-small);color:#fff;cursor:pointer;font-family:inherit;font-size:.875rem;padding:.75rem;transition:all .2s ease}.install-btn,.install-btn:hover{background:#548164;background:var(--color-success)}.logout-btn{border:none;border-radius:12px;border-radius:var(--radius-small);color:#fff;cursor:pointer;font-family:inherit;font-size:.875rem;padding:.75rem;transition:all .2s ease}.logout-btn,.logout-btn:hover{background:#c4554d;background:var(--color-error)}.page-header{background:#fff;background:var(--color-background);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--color-divider);padding:2rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.page-header h2{color:#373530;font-size:1.5rem}.content-area{padding:2rem}.mobile-header{align-items:center;background:#fff;background:var(--color-background);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--color-divider);display:none;justify-content:space-between;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1001}.menu-toggle{background:none;border:none;cursor:pointer;font-size:1.5rem;padding:.5rem}.mobile-header h1{font-size:1.25rem;margin:0}.user-name{color:#787774;color:var(--color-text-secondary);font-size:.875rem}.mobile-overlay{bottom:0;right:0;z-index:1001}.mobile-menu{background:#fff;background:var(--color-background);display:flex;flex-direction:column;height:100vh;left:0;overflow-y:auto;position:fixed;top:0;transform:translateX(-100%);transition:transform .3s ease;width:280px;z-index:1002}.mobile-menu.open{transform:translateX(0)}.mobile-menu-header{border-bottom:1px solid #fafafa;border-bottom:1px solid var(--color-surface);padding:2rem 1.5rem 1rem}.mobile-menu-header h2{color:#373530;color:var(--color-text-primary);font-size:1.5rem;font-weight:700;margin:0 0 .5rem}.mobile-menu-header p{color:#787774;color:var(--color-text-secondary);font-size:.875rem;margin:0}.mobile-menu-nav{flex:1 1;padding:1rem 0}.mobile-nav-item{align-items:center;background:none;border:none;color:#787774;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:1rem;padding:1rem 1.5rem;text-align:left;transition:all .2s ease;width:100%}.mobile-nav-item:hover{background:#fafafa;background:var(--color-surface);color:#373530;color:var(--color-text-primary)}.mobile-nav-item.active{background:#eef2ff;background:var(--color-hover);border-right:3px solid #6366f1;border-right:3px solid var(--color-primary);color:#6366f1;color:var(--color-primary);font-weight:500}.mobile-menu-footer{border-top:1px solid #fafafa;border-top:1px solid var(--color-surface);display:flex;flex-direction:column;gap:.5rem;padding:1rem 1.5rem}.mobile-install-btn{border:none;border-radius:12px;border-radius:var(--radius-small);color:#fff;cursor:pointer;font-family:inherit;font-size:.875rem;padding:.75rem;transition:all .2s ease}.mobile-install-btn,.mobile-install-btn:hover{background:#548164;background:var(--color-success)}.mobile-logout-btn{border:none;border-radius:12px;border-radius:var(--radius-small);color:#fff;cursor:pointer;font-family:inherit;font-size:.875rem;padding:.75rem;transition:all .2s ease}.mobile-logout-btn,.mobile-logout-btn:hover{background:#c4554d;background:var(--color-error)}@media (max-width:1024px){.mobile-header{display:flex}.sidebar{display:none}.main-content{margin-left:0;padding-top:70px}.card,.content-area,.page-header{padding:1rem}.card{margin-bottom:1rem}.form-group input,.form-group select,.form-group textarea{font-size:16px}}@media (max-width:768px){.mobile-menu{width:100%}.page-header h2{font-size:1.25rem}.content-area{padding:.75rem}}.calendar{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-divider);border-radius:12px;border-radius:var(--radius-small);box-shadow:0 1px 3px #0000001a;padding:1rem}.calendar-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem;padding:.5rem 0}.calendar-header h3{color:#373530;color:var(--color-text-primary);font-size:1.125rem;font-weight:600;margin:0}.calendar-nav{display:flex;gap:.5rem}.calendar-nav button{border:1px solid #e5e7eb;border:1px solid var(--color-divider);border-radius:6px;color:#787774;color:var(--color-text-secondary);cursor:pointer;font-size:.875rem;padding:.5rem;transition:all .2s ease}.calendar-nav button,.calendar-nav button:hover{background:#fafafa;background:var(--color-surface)}.calendar-nav button:hover{border-color:#d1d5db;border-color:var(--color-border)}.calendar-grid{grid-gap:1px;background:#e5e7eb;background:var(--color-divider);border-radius:12px;border-radius:var(--radius-small);display:grid;gap:1px;grid-template-columns:repeat(7,1fr);overflow:hidden}.calendar-day-header{background:#fafafa;background:var(--color-surface);color:#787774;color:var(--color-text-secondary);font-size:.75rem;font-weight:500;letter-spacing:.05em;padding:.75rem .5rem;text-align:center;text-transform:uppercase}.calendar-day{background:#fff;background:var(--color-background);border:1px solid #0000;color:#373530;color:var(--color-text-primary);cursor:pointer;display:flex;flex-direction:column;font-size:.875rem;justify-content:space-between;min-height:80px;padding:.5rem;text-align:left;transition:all .2s ease}.calendar-day:hover{border-color:#d1d5db;border-color:var(--color-border)}.calendar-day.other-month,.calendar-day:hover{background:#fafafa;background:var(--color-surface)}.calendar-day.other-month{color:#9ca3af;color:var(--color-inactive)}.calendar-day.today{background:#eef2ff;background:var(--color-hover);border-color:#6366f1;border-color:var(--color-primary);color:#6366f1;color:var(--color-primary);font-weight:600}.calendar-day.selected{border-color:#373530;border-color:var(--color-text-primary);color:#fff}.calendar-day.selected,.calendar-day.selected:hover{background:#373530;background:var(--color-text-primary)}@media (max-width:768px){.calendar-grid{gap:0}.calendar-day{font-size:.75rem;min-height:60px;padding:.25rem}.calendar-day-header{font-size:.7rem;padding:.5rem .25rem}}.install-prompt{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(135deg,#667eea,#764ba2);border:1px solid #ffffff1a;border-radius:20px;bottom:20px;box-shadow:0 20px 40px #0000004d;color:#fff;display:flex;justify-content:space-between;left:20px;padding:1.5rem;position:fixed;right:20px;z-index:1000}.install-prompt button{background:#ffffffe6;border:none;border-radius:12px;border-radius:var(--radius-small);color:#667eea;cursor:pointer;font-family:inherit;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.install-prompt button:hover{background:#fff;transform:translateY(-2px)}.App{color:var(--color-text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.App,.app-layout{background:var(--color-background);min-height:100vh}.app-layout,.sidebar{display:flex}.sidebar{background:var(--color-surface);border-right:1px solid var(--color-border);flex-direction:column;height:100vh;overflow-y:auto;position:fixed;width:280px}.sidebar-header{border-bottom:1px solid var(--color-border);padding:var(--spacing-24)}.sidebar-header h1{color:var(--color-text-primary);font-size:20px;font-weight:600;margin:0 0 8px}.sidebar-header p{color:var(--color-text-secondary);font-size:14px;margin:0}.sidebar-nav{flex:1 1;padding:var(--spacing-16)}.nav-section{margin-bottom:var(--spacing-24)}.nav-section h3{color:var(--color-text-secondary);font-size:12px;font-weight:600;letter-spacing:.5px;margin:0 0 var(--spacing-12) 0;padding:0 var(--spacing-12);text-transform:uppercase}.nav-item{align-items:center;background:none;border:none;border-radius:var(--radius-small);color:var(--color-text-primary);cursor:pointer;display:flex;font-size:14px;margin-bottom:4px;padding:10px var(--spacing-12);text-align:left;transition:all .2s ease;width:100%}.nav-item.active,.nav-item:hover{background:var(--color-hover);color:var(--color-primary)}.nav-item.active{font-weight:500}.sidebar-footer{border-top:1px solid var(--color-border);padding:var(--spacing-16)}.install-btn,.logout-btn{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-small);color:var(--color-text-primary);cursor:pointer;font-size:14px;margin-bottom:8px;padding:10px var(--spacing-12);transition:all .2s ease;width:100%}.install-btn:hover,.logout-btn:hover{background:var(--color-surface)}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:280px}.page-header{background:var(--color-hover);border-bottom:1px solid var(--color-border);padding:var(--spacing-24)}.page-header h2{color:var(--color-text-primary);font-size:24px;font-weight:600;margin:0}.content-area{flex:1 1;overflow-y:auto;padding:var(--spacing-24)}.card{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-small);box-shadow:0 1px 3px #0000001a;margin-bottom:var(--spacing-16);padding:var(--spacing-20);transition:all .2s ease}.card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-1px)}.card-header{margin-bottom:var(--spacing-16)}.card-title{color:var(--color-text-primary);font-size:16px;font-weight:600;margin:0 0 4px}.card-subtitle{color:var(--color-text-secondary);font-size:14px;margin:0}.btn-primary{background:var(--color-primary);border:none;border-radius:var(--radius-small);color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:12px 20px;transition:all .2s ease}.btn-primary:hover{background:#5856eb;transform:translateY(-1px)}.btn-secondary{background:#0000;border:1px solid var(--color-border);border-radius:var(--radius-small);color:var(--color-text-primary);cursor:pointer;font-size:14px;font-weight:500;padding:12px 20px;transition:all .2s ease}.btn-secondary:hover{background:var(--color-surface)}.form-group{margin-bottom:var(--spacing-16)}.form-label{display:block;font-weight:500;margin-bottom:6px}.form-input,.form-label,.form-select{color:var(--color-text-primary);font-size:14px}.form-input,.form-select{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-small);padding:12px;transition:border-color .2s ease;width:100%}.form-input:focus,.form-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f11a;outline:none}.summary-grid{grid-gap:var(--spacing-16);display:grid;gap:var(--spacing-16);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:var(--spacing-24)}.summary-card{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-small);padding:var(--spacing-20);text-align:center;transition:all .2s ease}.summary-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.summary-card.income{border-left:4px solid var(--color-success)}.summary-card.expense{border-left:4px solid var(--color-error)}.summary-card.balance{border-left:4px solid var(--color-info)}.summary-card h3{color:var(--color-text-secondary);font-size:14px;font-weight:500;margin:0 0 8px}.summary-card .amount{color:var(--color-text-primary);font-size:24px;font-weight:600;margin:0}.summary-card.income .amount{color:var(--color-success)}.summary-card.expense .amount{color:var(--color-error)}.summary-card.balance .amount{color:var(--color-info)}.transaction-item{align-items:center;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-small);display:flex;justify-content:space-between;margin-bottom:var(--spacing-12);padding:var(--spacing-16);transition:all .2s ease}.transaction-item:hover{background:var(--color-surface);transform:translateX(4px)}.transaction-item.income{border-left:4px solid var(--color-success)}.transaction-item.expense{border-left:4px solid var(--color-error)}.transaction-info{flex:1 1}.transaction-category{color:var(--color-text-primary);font-size:14px;font-weight:600;margin-bottom:4px}.transaction-description{color:var(--color-text-secondary);font-size:12px}.transaction-amount{font-size:16px;font-weight:600}.transaction-item.income .transaction-amount{color:var(--color-success)}.transaction-item.expense .transaction-amount{color:var(--color-error)}.transaction-date{color:var(--color-text-secondary);font-size:12px;margin-left:var(--spacing-12)}.ai-analysis-card{background:var(--color-hover);border:1px solid var(--color-primary);border-radius:var(--radius-small);padding:var(--spacing-20)}.ai-analysis-card,.ai-button{margin-bottom:var(--spacing-16)}.ai-button{background:var(--color-primary);border:none;border-radius:var(--radius-small);color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:14px 24px;transition:all .2s ease}.ai-button:hover{background:#5856eb;transform:translateY(-1px)}.ai-button:disabled{background:var(--color-text-secondary);cursor:not-allowed;transform:none}.analysis-result{background:var(--color-background);border:1px solid var(--color-border);border-left:4px solid var(--color-primary);border-radius:var(--radius-small);padding:var(--spacing-20)}.analysis-result pre{color:var(--color-text-primary);font-family:inherit;line-height:1.6;margin:0;white-space:pre-wrap}.empty-state{color:var(--color-text-secondary);padding:48px var(--spacing-20);text-align:center}.empty-state-icon{font-size:48px;margin-bottom:var(--spacing-16);opacity:.5}.empty-state-title{color:var(--color-text-primary);font-size:18px;font-weight:500;margin-bottom:8px}.empty-state-description{color:var(--color-text-secondary);font-size:14px}.loading{align-items:center;color:var(--color-text-secondary);display:flex;justify-content:center;padding:var(--spacing-24)}.loading-spinner{animation:spin 1s linear infinite;border-top:2px solid var(--color-border);border:2px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);height:20px;margin-right:var(--spacing-12);width:20px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.sidebar{transform:translateX(-100%);transition:transform .3s ease;z-index:1000}.sidebar.open{transform:translateX(0)}.main-content{margin-left:0}.page-header{padding:var(--spacing-16)}.page-header h2{font-size:20px}.content-area{padding:var(--spacing-16)}.summary-grid{gap:var(--spacing-12);grid-template-columns:1fr}.card{padding:var(--spacing-16)}.transaction-item{align-items:flex-start;flex-direction:column;gap:var(--spacing-12)}.transaction-amount{align-self:flex-end}.btn-primary,.btn-secondary{padding:14px;width:100%}}@media (max-width:480px){.page-header h2,.sidebar-header h1{font-size:18px}.summary-card .amount{font-size:20px}.card-title{font-size:14px}.transaction-category{font-size:13px}.transaction-amount{font-size:14px}}.mobile-menu-toggle{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-small);cursor:pointer;display:none;left:16px;padding:8px;position:fixed;top:16px;z-index:1001}@media (max-width:768px){.mobile-menu-toggle{display:block}}.mobile-overlay{background:#00000080;display:none;height:100%;left:0;position:fixed;top:0;width:100%;z-index:999}@media (max-width:768px){.mobile-overlay.open{display:block}}.toast-container{flex-direction:column;pointer-events:none;position:fixed;right:var(--spacing-24);top:var(--spacing-24);z-index:9999}.toast,.toast-container{display:flex;gap:var(--spacing-12)}.toast{align-items:flex-start;animation:toast-slide-in .3s ease-out;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-small);box-shadow:0 4px 12px #00000026;max-width:calc(100vw - 48px);padding:var(--spacing-16);pointer-events:auto;width:360px}.toast.toast-exit{animation:toast-fade-out .3s ease-in forwards}.toast--success{border-left:4px solid var(--color-success)}.toast--error{border-left:4px solid var(--color-error)}.toast--warning{border-left:4px solid var(--color-warning)}.toast--info{border-left:4px solid var(--color-info)}.toast__message{color:var(--color-text-primary);flex:1 1;font-size:14px;line-height:1.4}.toast__close{align-items:center;background:none;border:none;cursor:pointer;display:flex;justify-content:center;padding:0}@keyframes toast-slide-in{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@keyframes toast-fade-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.dialog-overlay{align-items:center;animation:dialog-overlay-in .2s ease-out;background:#00000080;display:flex;inset:0;justify-content:center;position:fixed;z-index:10000}.dialog{animation:dialog-scale-in .2s ease-out;background:var(--color-background);border-radius:var(--radius-standard);box-shadow:0 20px 60px #0000004d;max-width:calc(100vw - 48px);padding:var(--spacing-24);width:400px}.dialog__header{align-items:center;display:flex;gap:var(--spacing-12);margin-bottom:var(--spacing-16)}.dialog__icon{flex-shrink:0}.dialog__title{color:var(--color-text-primary);font-size:18px;font-weight:600;margin:0}.dialog__message{color:var(--color-text-secondary);font-size:14px;line-height:1.5}.dialog__message,.dialog__password-field{margin-bottom:var(--spacing-20)}.dialog__actions{display:flex;gap:var(--spacing-12);justify-content:flex-end}.dialog__cancel-btn{background:#0000;border:1px solid var(--color-border);border-radius:var(--radius-small);color:var(--color-text-primary);cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.dialog__cancel-btn:hover{background:var(--color-surface)}.dialog__confirm-btn{border:none;border-radius:var(--radius-small);cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.dialog__confirm-btn:disabled{cursor:not-allowed;opacity:.5}.btn-danger{background:var(--color-error);border:none;color:#fff}.btn-danger:hover{opacity:.9}@keyframes dialog-overlay-in{0%{opacity:0}to{opacity:1}}@keyframes dialog-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
/*# sourceMappingURL=main.7873e8ca.css.map*/