:root{--primary-purple: #9333ea;--primary-purple-dark: #7c3aed;--primary-purple-light: #a855f7;--primary-purple-neon: #c084fc;--secondary-purple: #6b21a8;--secondary-purple-dark: #581c87;--bg-dark: #0f0b1e;--bg-darker: #0a0814;--bg-card: #1a1625;--bg-card-hover: #252030;--text-primary: #f3f4f6;--text-secondary: #d1d5db;--text-muted: #9ca3af;--border-color: #2d1b3d;--border-hover: #3d2b4d;--success: #10b981;--error: #ef4444;--warning: #f59e0b;--info: #3b82f6;--shadow-sm: 0 2px 4px rgba(147, 51, 234, .1);--shadow-md: 0 4px 6px rgba(147, 51, 234, .15);--shadow-lg: 0 10px 15px rgba(147, 51, 234, .2);--shadow-neon: 0 0 20px rgba(147, 51, 234, .5);--sidebar-width: 260px;--sidebar-width-collapsed: 80px;--header-height: 64px;--sidebar-width-mobile: 280px;--header-height-mobile: 56px;--transition: all .3s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-dark);color:var(--text-primary);line-height:1.6;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-darker)}::-webkit-scrollbar-thumb{background:var(--primary-purple);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary-purple-light)}.btn{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;gap:8px}.btn-primary{background:linear-gradient(135deg,var(--primary-purple),var(--primary-purple-dark));color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover{background:linear-gradient(135deg,var(--primary-purple-light),var(--primary-purple));box-shadow:var(--shadow-neon);transform:translateY(-2px)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--border-hover)}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover{background:#dc2626}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:20px;transition:var(--transition)}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-lg)}.input{width:100%;padding:12px 16px;background:var(--bg-darker);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;transition:var(--transition)}.input:focus{outline:none;border-color:var(--primary-purple);box-shadow:0 0 0 3px #9333ea1a}.input::placeholder{color:var(--text-muted)}.spinner{border:3px solid var(--bg-card);border-top:3px solid var(--primary-purple);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.card{padding:16px}.btn{padding:8px 16px;font-size:13px}}.app{display:flex;min-height:100vh;background:var(--bg-dark);position:relative;width:100%;overflow-x:hidden}.main-content{flex:1;margin-left:var(--sidebar-width);transition:var(--transition);display:flex;flex-direction:column;width:100%;min-width:0}.sidebar.closed~.main-content{margin-left:var(--sidebar-width-collapsed)}.content{flex:1;margin-top:var(--header-height);padding:0;overflow-y:auto;min-height:calc(100vh - var(--header-height))}.network-error~.content{margin-top:calc(var(--header-height) + 80px)}@media(max-width:768px){.content{margin-top:var(--header-height-mobile);min-height:calc(100vh - var(--header-height-mobile))}.network-error~.content{margin-top:calc(var(--header-height-mobile) + 80px)}}.page-placeholder{padding:48px 24px;text-align:center;color:var(--text-muted)}.page-placeholder h2{font-size:24px;margin-bottom:12px;color:var(--text-primary)}@media(max-width:768px){.main-content{margin-left:0!important;width:100%!important}.sidebar.closed~.main-content,.sidebar.open~.main-content{margin-left:0!important;width:100%!important}}.sidebar{position:fixed;left:0;top:0;height:100vh;background:var(--bg-card);border-right:1px solid var(--border-color);transition:var(--transition);z-index:1000;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}.sidebar.open{width:var(--sidebar-width)}.sidebar.closed{width:var(--sidebar-width-collapsed)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--border-color);min-height:var(--header-height);flex-shrink:0}.sidebar-logo{display:flex;align-items:center;gap:12px}.logo-text{font-size:20px;font-weight:700;background:linear-gradient(135deg,var(--primary-purple),var(--primary-purple-neon));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logo-icon{font-size:28px}.sidebar-toggle{background:var(--bg-darker);border:1px solid var(--border-color);color:var(--text-primary);width:32px;height:32px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);font-size:14px}.sidebar-toggle:hover{background:var(--bg-card-hover);border-color:var(--primary-purple);color:var(--primary-purple-neon)}.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:8px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;color:var(--text-secondary);text-decoration:none;transition:var(--transition);position:relative}.nav-item:hover{background:var(--bg-card-hover);color:var(--text-primary);transform:translate(4px)}.nav-item.active{background:linear-gradient(135deg,#9333ea33,#a855f71a);color:var(--primary-purple-neon);border-left:3px solid var(--primary-purple)}.nav-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary-purple);box-shadow:var(--shadow-neon)}.nav-icon{font-size:20px;min-width:24px;display:flex;align-items:center;justify-content:center}.nav-label{font-size:14px;font-weight:500;white-space:nowrap}.sidebar-overlay{position:fixed;inset:0;background:#000000b3;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@media(max-width:768px){.sidebar{transform:translate(-100%);width:var(--sidebar-width-mobile);max-width:85vw;z-index:1001}.sidebar.open{transform:translate(0);width:var(--sidebar-width-mobile);max-width:85vw;z-index:1001}.sidebar.closed{transform:translate(-100%);width:0;overflow:hidden}.sidebar-header{padding:12px 16px;min-height:var(--header-height-mobile)}.logo-text{font-size:18px}.logo-icon{font-size:24px}.sidebar-toggle{width:36px;height:36px;font-size:16px}.sidebar-nav{padding:12px 8px;gap:6px}.nav-item{padding:10px 12px;gap:10px}.nav-icon{font-size:18px;min-width:20px}.nav-label{font-size:13px}}.modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;box-shadow:var(--shadow-neon);max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease;overflow:hidden}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-small{width:100%;max-width:400px}.modal-medium{width:100%;max-width:600px}.modal-large{width:100%;max-width:900px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color)}.modal-title{font-size:20px;font-weight:700;color:var(--text-primary);margin:0;background:linear-gradient(135deg,var(--primary-purple),var(--primary-purple-neon));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal-close{width:32px;height:32px;border-radius:6px;background:var(--bg-darker);border:1px solid var(--border-color);color:var(--text-primary);font-size:18px;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--error);border-color:var(--error);color:#fff;transform:rotate(90deg)}.modal-body{padding:24px;overflow-y:auto;flex:1}@media(max-width:768px){.modal-overlay{padding:10px}.modal-content{max-height:95vh}.modal-header{padding:16px 20px}.modal-title{font-size:18px}.modal-body{padding:20px}}.alert{display:flex;align-items:center;gap:12px;padding:14px 18px;border-radius:8px;border:1px solid;font-size:14px;font-weight:500;animation:slideDown .3s ease;position:relative;box-shadow:var(--shadow-md)}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.alert.show{animation:slideDown .3s ease}.alert.hide{animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(0);opacity:1}to{transform:translateY(-20px);opacity:0}}.alert-success{background:#10b9811a;border-color:var(--success);color:var(--success)}.alert-error{background:#ef44441a;border-color:var(--error);color:var(--error)}.alert-warning{background:#f59e0b1a;border-color:var(--warning);color:var(--warning)}.alert-info{background:#3b82f61a;border-color:var(--info);color:var(--info)}.alert-icon{font-size:18px;flex-shrink:0}.alert-message{flex:1}.alert-close{background:transparent;border:none;color:inherit;font-size:16px;cursor:pointer;padding:4px;opacity:.7;transition:var(--transition);flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px}.alert-close:hover{opacity:1;background:#ffffff1a}.settings-modal{padding:8px 0}.settings-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:1px solid var(--border-color)}.settings-tab{padding:12px 20px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:var(--transition)}.settings-tab:hover{color:var(--text-primary)}.settings-tab.active{color:var(--primary-purple-neon);border-bottom-color:var(--primary-purple)}.settings-form{display:flex;flex-direction:column;gap:20px}.settings-form .form-group{display:flex;flex-direction:column;gap:8px}.settings-form .form-group label{color:var(--text-primary);font-size:14px;font-weight:500}.settings-form .form-group input{padding:12px 16px;background:var(--bg-darker);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;transition:var(--transition);outline:none}.settings-form .form-group input:focus{border-color:var(--primary-purple);box-shadow:0 0 0 3px #9333ea1a}.settings-form .form-group input:disabled,.settings-form .form-group input.disabled-input{opacity:.6;cursor:not-allowed;background:var(--bg-card)}.settings-form .form-group input::placeholder{color:var(--text-muted)}.settings-button{padding:12px 24px;background:linear-gradient(135deg,var(--primary-purple),var(--primary-purple-light));border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:var(--transition);margin-top:8px}.settings-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}.settings-button:disabled{opacity:.6;cursor:not-allowed}.settings-button-danger{background:linear-gradient(135deg,var(--error),#ff5555)}.settings-button-danger:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#f44)}.settings-divider{height:1px;background:var(--border-color);margin:24px 0}.header{position:fixed;top:0;left:var(--sidebar-width);right:0;height:var(--header-height);background:var(--bg-card);border-bottom:1px solid var(--border-color);z-index:100;transition:var(--transition);display:flex;align-items:center}.sidebar.closed~.main-content .header{left:var(--sidebar-width-collapsed)}.header-content{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:100%;width:100%}.header-left{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.header-title{font-size:20px;font-weight:700;background:linear-gradient(135deg,var(--primary-purple),var(--primary-purple-neon));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-date{font-size:12px;color:var(--text-muted)}.header-right{display:flex;align-items:center;gap:12px}.header-user{display:flex;align-items:center;gap:8px}.header-username{color:var(--text-secondary);font-size:13px;font-weight:500;padding:6px 12px;background:var(--bg-darker);border-radius:6px;border:1px solid var(--border-color)}.header-actions{display:flex;gap:8px}.header-btn{width:40px;height:40px;border-radius:8px;background:var(--bg-darker);border:1px solid var(--border-color);color:var(--text-primary);font-size:18px;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;flex-shrink:0}.header-menu-toggle{display:none}.header-btn:hover{background:var(--bg-card-hover);border-color:var(--primary-purple);transform:scale(1.05)}@media(max-width:768px){.header{left:0!important;right:0!important;height:var(--header-height-mobile)}.sidebar.closed~.main-content .header,.sidebar.open~.main-content .header{left:0!important}.header-content{padding:0 12px;gap:8px}.header-left{gap:2px;flex:1;min-width:0}.header-title{font-size:16px;line-height:1.2}.header-date{font-size:10px;line-height:1.2}.header-menu-toggle{display:flex;width:36px;height:36px;margin-right:4px}.header-actions{gap:6px}.header-btn{width:36px;height:36px;font-size:16px}.header-right{gap:6px;flex-shrink:0}}.network-error{position:fixed;top:var(--header-height);left:0;right:0;z-index:2000;padding:16px;background:#ef4444f2;border-bottom:2px solid var(--error);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.network-error-content{display:flex;align-items:center;gap:12px;max-width:1200px;margin:0 auto;position:relative}.error-close{background:#fff3;border:none;color:#fff;width:28px;height:28px;border-radius:4px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:var(--transition);flex-shrink:0}.error-close:hover{background:#ffffff4d}.error-icon{font-size:24px;flex-shrink:0}.error-text{flex:1;color:#fff}.error-text strong{display:block;font-size:14px;font-weight:700;margin-bottom:4px}.error-text p{margin:4px 0;font-size:12px;opacity:.9}.error-hint{font-size:11px;opacity:.8;font-style:italic}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-dark);padding:20px;position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(147,51,234,.1) 0%,transparent 70%);animation:pulse 8s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.1);opacity:.8}}.login-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:40px;width:100%;max-width:420px;box-shadow:var(--shadow-lg);position:relative;z-index:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-header{text-align:center;margin-bottom:32px}.login-logo{font-size:64px;margin-bottom:16px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.login-title{font-size:28px;font-weight:700;background:linear-gradient(135deg,var(--primary-purple),var(--primary-purple-neon));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 8px}.login-subtitle{color:var(--text-secondary);font-size:14px;margin:0}.login-form{display:flex;flex-direction:column;gap:20px}.form-group label{color:var(--text-primary);font-size:14px;font-weight:500}.form-group input{padding:12px 16px;background:var(--bg-darker);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;transition:var(--transition);outline:none}.form-group input:focus{border-color:var(--primary-purple);box-shadow:0 0 0 3px #9333ea1a}.form-group input:disabled{opacity:.6;cursor:not-allowed}.form-group input::placeholder{color:var(--text-muted)}.login-button{padding:14px 24px;background:linear-gradient(135deg,var(--primary-purple),var(--primary-purple-light));border:none;border-radius:8px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:var(--transition);margin-top:8px;box-shadow:var(--shadow-md)}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:24px;text-align:center}.login-hint{color:var(--text-muted);font-size:12px;margin:0}.login-hint strong{color:var(--text-secondary)}@media(max-width:768px){.login-card{padding:32px 24px}.login-logo{font-size:48px}.login-title{font-size:24px}.login-subtitle{font-size:13px}}.dashboard{padding:24px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:16px}.dashboard-header h2{font-size:28px;font-weight:700;background:linear-gradient(135deg,var(--primary-purple),var(--primary-purple-neon));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.month-selector{display:flex;gap:8px}.dashboard-loading,.dashboard-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.dashboard-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:24px}.summary-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;display:flex;align-items:center;gap:16px;transition:var(--transition);position:relative;overflow:hidden}.summary-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-purple),var(--primary-purple-neon));opacity:0;transition:var(--transition)}.summary-card:hover{border-color:var(--primary-purple);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.summary-card:hover:before{opacity:1}.summary-card.income:before{background:linear-gradient(90deg,var(--success),#34d399)}.summary-card.expense:before{background:linear-gradient(90deg,var(--error),#f87171)}.summary-card.balance:before{background:linear-gradient(90deg,var(--info),#60a5fa)}.summary-card.percentage:before{background:linear-gradient(90deg,var(--warning),#fbbf24)}.summary-icon{font-size:40px;width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:var(--bg-darker);border-radius:12px;flex-shrink:0}.summary-content{flex:1}.summary-content h3{font-size:14px;font-weight:500;color:var(--text-muted);margin:0 0 8px;text-transform:uppercase;letter-spacing:.5px}.summary-amount{font-size:24px;font-weight:700;color:var(--text-primary);margin:0}.summary-amount.positive{color:var(--success)}.summary-amount.negative{color:var(--error)}.dashboard-budget,.dashboard-categories{margin-bottom:24px}.dashboard-budget .card h3,.dashboard-categories .card h3{font-size:20px;font-weight:700;margin:0 0 20px;color:var(--text-primary)}.budget-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.budget-item{display:flex;flex-direction:column;gap:8px;padding:16px;background:var(--bg-darker);border-radius:8px;border:1px solid var(--border-color)}.budget-item span{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.budget-item strong{font-size:18px;font-weight:700;color:var(--text-primary)}.budget-item strong.positive{color:var(--success)}.budget-item strong.negative{color:var(--error)}.categories-list{display:flex;flex-direction:column;gap:12px}.category-item{display:flex;align-items:center;gap:16px;padding:16px;background:var(--bg-darker);border-radius:8px;border:1px solid var(--border-color);transition:var(--transition)}.category-item:hover{border-color:var(--primary-purple);transform:translate(4px)}.category-rank{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-purple),var(--primary-purple-dark));color:#fff;border-radius:6px;font-weight:700;font-size:14px}.category-icon{font-size:24px}.category-name{font-size:14px;font-weight:500;color:var(--text-primary)}.category-amount{font-size:16px;font-weight:700;color:var(--primary-purple-neon)}@media(max-width:768px){.dashboard{padding:16px}.dashboard-summary{grid-template-columns:1fr}.summary-card{padding:20px}.summary-icon{width:56px;height:56px;font-size:32px}.summary-amount{font-size:20px}.budget-info{grid-template-columns:1fr}}.transactions{padding:24px}.transactions-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:16px}.transactions-header h2{font-size:28px;font-weight:700;background:linear-gradient(135deg,var(--primary-purple),var(--primary-purple-neon));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.transactions-loading,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.empty-state p{color:var(--text-muted);font-size:16px}.transactions-list{display:flex;flex-direction:column;gap:16px}.transaction-card{display:flex;gap:16px;align-items:flex-start;transition:var(--transition);position:relative}.transaction-card:hover{transform:translate(4px)}.transaction-actions{display:flex;gap:8px;flex-shrink:0}.transaction-form{display:flex;flex-direction:column;gap:20px}.form-group textarea{resize:vertical;font-family:inherit}.transaction-icon{font-size:32px;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--bg-darker);border-radius:12px;flex-shrink:0}.transaction-info{flex:1;display:flex;flex-direction:column;gap:8px}.transaction-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.transaction-header h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.transaction-type{padding:4px 12px;border-radius:6px;font-size:12px;font-weight:500;text-transform:uppercase}.transaction-type.income{background:#10b98133;color:var(--success)}.transaction-type.expense{background:#ef444433;color:var(--error)}.transaction-description{font-size:14px;color:var(--text-secondary);margin:0}.transaction-footer{display:flex;align-items:center;justify-content:space-between;gap:12px}.transaction-date{font-size:12px;color:var(--text-muted)}.transaction-amount{font-size:18px;font-weight:700}.transaction-amount.income{color:var(--success)}.transaction-amount.expense{color:var(--error)}.transactions-controls{display:flex;align-items:center;gap:16px;margin-bottom:20px;padding:16px;background:var(--bg-darker);border-radius:8px;flex-wrap:wrap}.control-group .input{min-width:150px}@media(max-width:768px){.transactions{padding:16px}.transaction-card{flex-direction:column}.transaction-icon{width:48px;height:48px;font-size:24px}.transactions-controls{flex-direction:column;align-items:stretch}.control-group{width:100%;justify-content:space-between}.pagination{flex-direction:column;gap:12px}.pagination .btn{width:100%}}.categories{padding:24px}.categories-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:16px}.categories-header h2{font-size:28px;font-weight:700;background:linear-gradient(135deg,var(--primary-purple),var(--primary-purple-neon));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.categories-filters{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}.filter-btn{padding:10px 20px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);border-radius:8px;cursor:pointer;transition:var(--transition);font-size:14px;font-weight:500}.filter-btn:hover{border-color:var(--primary-purple);color:var(--text-primary)}.filter-btn.active{background:linear-gradient(135deg,var(--primary-purple),var(--primary-purple-dark));border-color:var(--primary-purple);color:#fff}.categories-loading,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.category-card{display:flex;align-items:center;gap:16px;padding:20px;transition:var(--transition)}.category-card:hover{transform:translateY(-4px)}.category-icon{font-size:40px;width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:var(--bg-darker);border-radius:12px;flex-shrink:0}.category-info{flex:1;display:flex;flex-direction:column;gap:4px}.category-info h3{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.category-type{font-size:12px;padding:4px 8px;border-radius:4px;display:inline-block;width:fit-content}.category-type.income{background:#10b98133;color:var(--success)}.category-type.expense{background:#ef444433;color:var(--error)}.category-actions{display:flex;gap:8px}.category-form{display:flex;flex-direction:column;gap:20px}@media(max-width:768px){.categories{padding:16px}.categories-grid{grid-template-columns:1fr}.category-card{padding:16px}}.budgets{padding:24px}.budgets-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:16px}.budgets-header h2{font-size:28px;font-weight:700;background:linear-gradient(135deg,var(--primary-purple),var(--primary-purple-neon));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.header-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.budgets-loading,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.budget-total{margin-bottom:24px;padding:24px}.budget-total-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.budget-total-header h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0}.budget-amount{font-size:32px;font-weight:700;color:var(--primary-purple-neon)}.budgets-list h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 20px}.budgets-list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:16px}.budgets-controls{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.budgets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.budget-card{padding:20px}.budget-card-header{display:flex;align-items:center;justify-content:space-between}.budget-category{display:flex;align-items:center;gap:12px;flex:1}.budget-icon{font-size:32px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--bg-darker);border-radius:10px}.budget-category h4{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.budget-amount-small{font-size:14px;color:var(--text-secondary)}.budget-actions{display:flex;gap:8px}.btn-icon{width:36px;height:36px;border-radius:6px;background:var(--bg-darker);border:1px solid var(--border-color);color:var(--text-primary);font-size:16px;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}.btn-icon:hover{background:var(--bg-card-hover);border-color:var(--primary-purple);transform:scale(1.1)}.btn-icon.btn-danger:hover{background:var(--error);border-color:var(--error);color:#fff}.budget-form{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}@media(max-width:768px){.budgets{padding:16px}.budgets-grid,.form-row{grid-template-columns:1fr}.budgets-list-header{flex-direction:column;align-items:stretch}.budgets-controls{width:100%;flex-direction:column;gap:12px}.control-group{width:100%;justify-content:space-between}.pagination{flex-direction:column;gap:12px}.pagination .btn{width:100%}}.achievements{padding:24px}.achievements-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:32px;flex-wrap:wrap;gap:16px}.achievements-header h2{font-size:28px;font-weight:700;background:linear-gradient(135deg,var(--primary-purple),var(--primary-purple-neon));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 8px}.achievements-subtitle{font-size:14px;color:var(--text-muted);margin:0}.achievements-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.achievement-section{margin-bottom:32px}.achievement-section h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 20px}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.achievement-card{position:relative;padding:24px;transition:var(--transition)}.achievement-card.locked{opacity:.7;border-color:var(--border-color)}.achievement-card.unlocked{border-color:var(--primary-purple);box-shadow:var(--shadow-neon)}.achievement-card:hover{transform:translateY(-4px)}.achievement-icon{font-size:48px;text-align:center;margin-bottom:16px}.achievement-content{text-align:center}.achievement-content h4{font-size:18px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.achievement-description{font-size:14px;color:var(--text-secondary);margin:0 0 16px;min-height:40px}.achievement-progress{margin-top:16px}.progress-bar{width:100%;height:8px;background:var(--bg-darker);border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-purple),var(--primary-purple-neon));transition:width .3s ease;border-radius:4px}.achievement-card.unlocked .progress-fill{background:linear-gradient(90deg,var(--success),#34d399)}.progress-text{font-size:12px;color:var(--text-muted);display:block}.achievement-reasoning{font-size:12px;color:var(--text-muted);font-style:italic;margin:12px 0 0;padding-top:12px;border-top:1px solid var(--border-color)}.achievement-badge{position:absolute;top:16px;right:16px;width:32px;height:32px;background:var(--success);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;box-shadow:var(--shadow-md)}@media(max-width:768px){.achievements{padding:16px}.achievements-grid{grid-template-columns:1fr}}.reports{padding:24px}.reports-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:16px}.reports-layout{display:grid;grid-template-columns:400px 1fr;gap:24px;align-items:start}.reports-header h2{font-size:28px;font-weight:700;background:linear-gradient(135deg,var(--primary-purple),var(--primary-purple-neon));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.reports-loading,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.reports-filters{margin-bottom:24px}.reports-filters h3{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 20px}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:20px}.filters-grid .full-width{grid-column:1 / -1}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:500;color:var(--text-primary)}.filters-actions{display:flex;gap:12px;justify-content:flex-end}.reports-summary{margin-bottom:24px}.reports-summary h3{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 20px}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.summary-item{display:flex;flex-direction:column;gap:8px;padding:16px;background:var(--bg-darker);border-radius:8px;border:1px solid var(--border-color)}.summary-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.summary-value{font-size:20px;font-weight:700;color:var(--text-primary)}.summary-value.income{color:var(--success)}.summary-value.expense{color:var(--error)}.reports-list h3{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 20px}.reports-list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:16px}.reports-controls{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.control-group{display:flex;align-items:center;gap:8px}.control-group label{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap}.control-group .input{min-width:120px}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:24px;padding:16px;background:var(--bg-darker);border-radius:8px}.pagination-info{font-size:14px;color:var(--text-secondary);font-weight:500}.pagination .btn{min-width:120px}.pagination .btn:disabled{opacity:.5;cursor:not-allowed}.transactions-table{overflow-x:auto}.transactions-table table{width:100%;border-collapse:collapse;background:var(--bg-card);border-radius:8px;overflow:hidden}.transactions-table thead{background:var(--bg-darker)}.transactions-table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.transactions-table td{padding:16px;border-top:1px solid var(--border-color);font-size:14px;color:var(--text-primary)}.transactions-table tbody tr:hover{background:var(--bg-card-hover)}.category-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;background:var(--bg-darker);border-radius:4px;font-size:13px}.type-badge{padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.type-badge.income{background:#10b98133;color:var(--success)}.type-badge.expense{background:#ef444433;color:var(--error)}.amount{font-weight:700}.amount.income{color:var(--success)}.amount.expense{color:var(--error)}.reports-left-column{position:sticky;top:calc(var(--header-height) + 24px);max-height:calc(100vh - var(--header-height) - 48px);overflow-y:auto;padding-right:8px}.reports-left-column::-webkit-scrollbar{width:6px}.reports-left-column::-webkit-scrollbar-track{background:transparent;border-radius:3px}.reports-left-column::-webkit-scrollbar-thumb{background:var(--primary-purple);border-radius:3px}.reports-left-column::-webkit-scrollbar-thumb:hover{background:var(--primary-purple-neon)}.reports-right-column{min-width:0}.ai-summary-section{background:linear-gradient(135deg,#9333ea1a,#a855f70d);border:1px solid var(--primary-purple);position:relative}.ai-summary-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:16px}.ai-summary-header h3{font-size:20px;font-weight:700;background:linear-gradient(135deg,var(--primary-purple),var(--primary-purple-neon));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 4px}.ai-summary-subtitle{font-size:13px;color:var(--text-muted);margin:0}.ai-summary-controls{display:flex;align-items:center;gap:8px}.ai-summary-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;gap:16px}.ai-summary-loading .spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-purple);border-radius:50%;animation:spin 1s linear infinite}.ai-summary-content{display:flex;flex-direction:column;gap:20px}.ai-summary-text{padding:16px;background:var(--bg-darker);border-radius:8px;border-left:3px solid var(--primary-purple)}.ai-summary-text h4{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.ai-summary-text p{font-size:14px;line-height:1.6;color:var(--text-secondary);margin:0;white-space:pre-line}.ai-summary-insights,.ai-summary-recommendations{padding:16px;background:var(--bg-darker);border-radius:8px}.ai-summary-insights{border-left:3px solid var(--info)}.ai-summary-recommendations{border-left:3px solid var(--success)}.ai-summary-insights h4,.ai-summary-recommendations h4{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.ai-summary-insights ul,.ai-summary-recommendations ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.ai-summary-insights li,.ai-summary-recommendations li{font-size:14px;line-height:1.6;color:var(--text-secondary);padding-left:20px;position:relative}.ai-summary-insights li:before{content:"💡";position:absolute;left:0}.ai-summary-recommendations li:before{content:"✓";position:absolute;left:0;color:var(--success);font-weight:700}.ai-summary-footer{padding-top:16px;border-top:1px solid var(--border-color);text-align:right}.ai-summary-footer small{font-size:12px;color:var(--text-muted)}.ai-summary-empty{padding:40px;text-align:center;color:var(--text-muted)}@media(max-width:1024px){.reports-layout{grid-template-columns:1fr;gap:20px}.reports-left-column{position:relative;top:0;max-height:none;overflow-y:visible;padding-right:0}}@media(max-width:768px){.reports{padding:16px}.reports-layout{gap:16px}.filters-grid,.summary-grid{grid-template-columns:1fr}.transactions-table{font-size:12px}.transactions-table th,.transactions-table td{padding:8px}.ai-summary-header{flex-direction:column}.ai-summary-controls{width:100%;justify-content:space-between}.ai-summary-controls select{flex:1}.reports-left-column{position:relative;top:0;max-height:none}.reports-list-header{flex-direction:column;align-items:stretch}.reports-controls{width:100%;flex-direction:column;gap:12px}.control-group{width:100%;justify-content:space-between}.pagination{flex-direction:column;gap:12px}.pagination .btn{width:100%}}.loading-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-dark);gap:16px}.loading-spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--primary-purple);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container p{color:var(--text-secondary);font-size:14px}
