@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap";:root{--bg-main:#0a0b10;--bg-sidebar:#0d0f18e6;--bg-card:#14162599;--bg-card-hover:#1c1f35cc;--border-color:#ffffff0f;--border-color-active:#818cf866;--primary:#6366f1;--primary-hover:#4f46e5;--primary-glow:#6366f126;--income:#10b981;--income-bg:#10b9811a;--income-glow:#10b98133;--expense:#ef4444;--expense-bg:#ef44441a;--expense-glow:#ef444433;--investment:#f59e0b;--investment-bg:#f59e0b1a;--investment-glow:#f59e0b33;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--text-muted:#6b7280;--text-dark:#111827;--font-display:"Outfit", -apple-system, BlinkMacSystemFont, sans-serif;--font-body:"Plus Jakarta Sans", -apple-system, sans-serif;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000004d, 0 4px 6px -2px #00000026;--shadow-glow:0 0 20px #6366f140;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-full:9999px;--transition-fast:.15s ease;--transition-normal:.25s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-main);color:var(--text-primary);font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;overflow-x:hidden}#root{width:100%;min-height:100vh;display:flex}button,input,select,textarea{color:inherit;font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-main)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.glass-card{background:var(--bg-card);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);transition:border-color var(--transition-normal), transform var(--transition-normal), background var(--transition-normal);padding:24px}.glass-card:hover{background:var(--bg-card-hover);border-color:#ffffff1f}.app-container{width:100%;min-height:100vh;display:flex;position:relative}.sidebar{background:var(--bg-sidebar);border-right:1px solid var(--border-color);z-index:50;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);flex-direction:column;width:280px;padding:32px 24px;display:flex;position:fixed;top:0;bottom:0;left:0}.main-content{box-sizing:border-box;flex-direction:column;flex:1;gap:32px;min-height:100vh;margin-left:280px;padding:40px 48px;display:flex;overflow-y:auto}.nav-menu{flex-direction:column;flex-grow:1;gap:8px;margin-top:32px;list-style:none;display:flex}.nav-item{border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;align-items:center;gap:12px;padding:12px 16px;font-weight:500;display:flex}.nav-item:hover{color:var(--text-primary);background:#ffffff0a}.nav-item.active{color:#fff;background:var(--primary-glow);border-color:#6366f140;box-shadow:0 0 15px #6366f11a}.nav-item-icon{flex-shrink:0;width:20px;height:20px}.page-title-container{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.page-title{font-family:var(--font-display);letter-spacing:-.02em;background:linear-gradient(135deg,#fff 30%,#a5b4fc 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:32px;font-weight:700}.page-subtitle{color:var(--text-secondary);margin-top:4px;font-size:14px}.btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal);border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;display:inline-flex}.btn-primary{background:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{background:var(--primary-hover);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-secondary{border-color:var(--border-color);color:var(--text-primary);background:#ffffff0d}.btn-secondary:hover{background:#ffffff14;border-color:#fff3}.btn-danger{background:var(--expense-bg);color:#fca5a5;border-color:#ef444433}.btn-danger:hover{background:var(--expense);color:#fff;transform:translateY(-1px)}.btn-icon-only{border-radius:var(--radius-sm);padding:8px}.form-group{flex-direction:column;gap:8px;margin-bottom:20px;display:flex}.form-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-size:12px;font-weight:600}.form-input,.form-select,.form-textarea{border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:all var(--transition-fast);background:#0a0b10cc;padding:12px 16px;font-size:14px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);background:#0a0b10f2;outline:none;box-shadow:0 0 0 3px #6366f126}.form-textarea{resize:vertical;min-height:80px}.input-row{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;display:grid}.table-container{border-radius:var(--radius-lg);border:1px solid var(--border-color);background:#0d0f184d;overflow-x:auto}.custom-table{border-collapse:collapse;text-align:left;width:100%;font-size:14px}.custom-table th{color:var(--text-secondary);border-bottom:1px solid var(--border-color);text-transform:uppercase;letter-spacing:.05em;background:#14162580;padding:16px 20px;font-size:11px;font-weight:600}.custom-table td{border-bottom:1px solid var(--border-color);color:var(--text-primary);padding:16px 20px}.custom-table tbody tr{transition:background var(--transition-fast)}.custom-table tbody tr:hover{background:#ffffff05}.custom-table tbody tr:last-child td{border-bottom:none}.badge{text-transform:uppercase;border-radius:var(--radius-full);align-items:center;gap:6px;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}.badge-income{background:var(--income-bg);color:#34d399;border:1px solid #10b98133}.badge-expense{background:var(--expense-bg);color:#f87171;border:1px solid #ef444433}.badge-investment{background:var(--investment-bg);color:#fbbf24;border:1px solid #f59e0b33}.badge-refund{color:#a78bfa;background:#8b5cf626;border:1px solid #8b5cf633}.badge-transfer{color:#22d3ee;background:#06b6d426;border:1px solid #06b6d433}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;background:#050609d9;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{border-radius:var(--radius-lg);background:#141625;border:1px solid #ffffff14;flex-direction:column;width:100%;max-width:540px;animation:.3s cubic-bezier(.16,1,.3,1) modalAppear;display:flex;box-shadow:0 25px 50px -12px #00000080}@keyframes modalAppear{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-title{font-family:var(--font-display);font-size:20px;font-weight:600}.modal-body{max-height:70vh;padding:24px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;display:grid}.metric-card{position:relative;overflow:hidden}.metric-card:after{content:"";width:4px;height:100%;position:absolute;top:0;left:0}.metric-card.income-card:after{background:var(--income)}.metric-card.expense-card:after{background:var(--expense)}.metric-card.investment-card:after{background:var(--investment)}.metric-card.net-card:after{background:var(--primary)}.metric-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:12px;font-weight:600}.metric-value{font-family:var(--font-display);font-size:28px;font-weight:700}.metric-change{align-items:center;gap:4px;margin-top:8px;font-size:11px;display:flex}.book-selector-container{border:1px solid var(--border-color);border-radius:var(--radius-md);background:#ffffff08;align-items:center;gap:12px;margin-top:8px;padding:6px 12px;display:flex}.book-selector-select{font-family:var(--font-display);color:var(--text-primary);cursor:pointer;background:0 0;border:none;padding-right:8px;font-size:15px;font-weight:600}.book-selector-select:focus{outline:none}.charts-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}@media (width<=1024px){.charts-grid{grid-template-columns:1fr}}.chart-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.chart-title{font-family:var(--font-display);font-size:18px;font-weight:600}.bar-chart-container{flex-direction:column;gap:14px;margin-top:10px;display:flex}.bar-row{flex-direction:column;gap:6px;display:flex}.bar-info{justify-content:space-between;font-size:13px;display:flex}.bar-label{color:var(--text-primary);font-weight:500}.bar-percentage{color:var(--text-secondary)}.bar-track{border-radius:var(--radius-full);background:#ffffff0d;height:8px;overflow:hidden}.bar-fill{border-radius:var(--radius-full);height:100%;transition:width .6s}.sync-panel{flex-direction:column;gap:16px;display:flex}.sync-status{align-items:center;gap:8px;font-size:14px;font-weight:500;display:flex}.sync-indicator{border-radius:var(--radius-full);width:8px;height:8px}.sync-indicator.online{background:var(--income);box-shadow:0 0 10px var(--income-glow)}.sync-indicator.offline{background:var(--investment);box-shadow:0 0 10px var(--investment-glow)}.mobile-nav{display:none}@media (width<=900px){.sidebar{display:none}.main-content{margin-left:0;padding:24px 20px 80px}.mobile-nav{background:var(--bg-sidebar);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-top:1px solid var(--border-color);z-index:100;justify-content:space-around;padding:10px 0;display:flex;position:fixed;bottom:0;left:0;right:0}.mobile-nav-item{color:var(--text-secondary);flex-direction:column;align-items:center;gap:4px;font-size:10px;font-weight:500;text-decoration:none;display:flex}.mobile-nav-item.active{color:var(--primary)}.mobile-nav-item svg{width:20px;height:20px}}.flex-row-center{align-items:center;display:flex}.justify-between{justify-content:space-between}.gap-sm{gap:8px}.gap-md{gap:16px}.text-right{text-align:right}.text-center{text-align:center}.cursor-pointer{cursor:pointer}
