@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=DM+Mono:wght@400;500&family=Syne:wght@700;800&display=swap";:root{--text: #6b6375;--text-h: #08060d;--bg: #fff;--border: #e5e4e7;--code-bg: #f4f3ec;--accent: #aa3bff;--accent-bg: rgba(170, 59, 255, .1);--accent-border: rgba(170, 59, 255, .5);--social-bg: rgba(244, 243, 236, .5);--shadow: rgba(0, 0, 0, .1) 0 10px 15px -3px, rgba(0, 0, 0, .05) 0 4px 6px -2px;--sans: system-ui, "Segoe UI", Roboto, sans-serif;--heading: system-ui, "Segoe UI", Roboto, sans-serif;--mono: ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (max-width: 1024px){:root{font-size:16px}}@media (prefers-color-scheme: dark){:root{--text: #9ca3af;--text-h: #f3f4f6;--bg: #16171d;--border: #2e303a;--code-bg: #1f2028;--accent: #c084fc;--accent-bg: rgba(192, 132, 252, .15);--accent-border: rgba(192, 132, 252, .5);--social-bg: rgba(47, 48, 58, .5);--shadow: rgba(0, 0, 0, .4) 0 10px 15px -3px, rgba(0, 0, 0, .25) 0 4px 6px -2px}#social .button-icon{filter:invert(1) brightness(2)}}body{margin:0}#root{width:1126px;max-width:100%;margin:0 auto;text-align:center;border-inline:1px solid var(--border);min-height:100svh;display:flex;flex-direction:column;box-sizing:border-box}h1,h2{font-family:var(--heading);font-weight:500;color:var(--text-h)}h1{font-size:56px;letter-spacing:-1.68px;margin:32px 0}@media (max-width: 1024px){h1{font-size:36px;margin:20px 0}}h2{font-size:24px;line-height:118%;letter-spacing:-.24px;margin:0 0 8px}@media (max-width: 1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);display:inline-flex;border-radius:4px;color:var(--text-h)}code{font-size:15px;line-height:135%;padding:4px 8px;background:var(--code-bg)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:var(--bg-secondary);border:2px solid var(--border);cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);color:var(--text-primary);box-shadow:0 2px 8px #0000001a;position:relative;overflow:hidden}.theme-toggle:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle,rgba(99,102,241,.2) 0%,transparent 70%);opacity:0;transition:opacity .3s ease}.theme-toggle:hover{border-color:var(--primary);box-shadow:0 4px 12px #6366f133;transform:translateY(-2px)}.theme-toggle:hover:before{opacity:1}.theme-toggle:active{transform:translateY(0)}.toggle-icon{display:flex;align-items:center;justify-content:center;position:relative;width:100%;height:100%}.icon-sun,.icon-moon{position:absolute;animation:iconRotate .5s ease}.icon-sun{animation-name:sunRotate}.icon-moon{animation-name:moonRotate}@keyframes sunRotate{0%{transform:rotate(0) scale(1);opacity:0}50%{opacity:1}to{transform:rotate(180deg) scale(1);opacity:1}}@keyframes moonRotate{0%{transform:rotate(180deg) scale(1);opacity:1}50%{opacity:1}to{transform:rotate(360deg) scale(1);opacity:0}}[data-theme=dark] .theme-toggle{background:var(--bg-secondary);border-color:var(--border);color:var(--primary-light)}[data-theme=dark] .theme-toggle:hover{border-color:var(--primary-light);box-shadow:0 4px 12px #a5b4fc4d}.currency-selector{position:relative;display:inline-block}.currency-button{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:8px;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--mid) ease;white-space:nowrap}.currency-button:hover{border-color:var(--accent);background:var(--bg-card);box-shadow:0 2px 8px #6366f11a}.currency-button:active{transform:scale(.98)}.currency-symbol{font-weight:600;color:var(--primary);font-size:16px}.currency-code{font-family:DM Mono,monospace;font-size:12px;color:var(--text-secondary)}.chevron{transition:transform var(--fast) ease;color:var(--text-secondary)}.chevron.open{transform:rotate(180deg)}.currency-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);z-index:1000;min-width:280px;animation:modalIn var(--mid) var(--ease) both}.currency-header{padding:12px 16px;border-bottom:1px solid var(--border-strong);background:var(--bg-card)}.currency-header h4{margin:0;font-size:14px;font-weight:600;color:var(--text-primary)}.currency-list{display:flex;flex-direction:column;max-height:400px;overflow-y:auto;background:var(--bg-card)}.currency-option{display:flex;align-items:center;gap:12px;padding:9px 12px;background:transparent;border:none;border-radius:var(--r-md);color:var(--text-secondary);cursor:pointer;transition:all var(--fast) ease;text-align:left;font-size:13px;font-weight:500;font-family:inherit;width:100%}.currency-option:hover{background:var(--accent-dim);color:var(--text-primary)}.currency-option.active{color:var(--accent);font-weight:600}.currency-flag{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--bg-secondary);border-radius:6px;font-size:16px;font-weight:600;color:var(--primary)}.currency-option.active .currency-flag{background:#6366f126}.currency-info{display:flex;flex-direction:column;flex:1}.currency-code-option{font-size:13px;font-weight:600;font-family:DM Mono,monospace;color:var(--text-primary)}.currency-name{font-size:12px;color:var(--text-secondary)}.checkmark{color:#10b981;font-weight:700;font-size:16px}:root[data-theme=dark] .currency-button{background:var(--bg-secondary);border-color:var(--border);color:var(--text-primary)}:root[data-theme=dark] .currency-button:hover{border-color:var(--primary);background:var(--bg-secondary);box-shadow:0 2px 8px #818cf833}:root[data-theme=dark] .currency-symbol{color:var(--primary)}:root[data-theme=dark] .currency-code{color:var(--text-secondary)}:root[data-theme=dark] .chevron{color:var(--text-secondary)}:root[data-theme=dark] .currency-dropdown{background:var(--bg-secondary);border-color:var(--border);box-shadow:var(--shadow-lg)}:root[data-theme=dark] .currency-header{background:var(--bg-tertiary);border-bottom-color:var(--border)}:root[data-theme=dark] .currency-header h4{color:var(--text-primary)}:root[data-theme=dark] .currency-list{background:var(--bg-secondary)}:root[data-theme=dark] .currency-option{color:var(--text-secondary)}:root[data-theme=dark] .currency-option:hover{background:#818cf81a;color:var(--text-primary)}:root[data-theme=dark] .currency-option.active{color:var(--primary);font-weight:600}:root[data-theme=dark] .currency-flag{background:var(--bg-tertiary);color:var(--primary)}:root[data-theme=dark] .currency-option.active .currency-flag{background:#818cf826}:root[data-theme=dark] .currency-info{flex:1}:root[data-theme=dark] .currency-code-option{color:var(--text-primary)}:root[data-theme=dark] .currency-name{color:var(--text-secondary)}:root[data-theme=dark] .checkmark{color:#34d399}@media (max-width: 640px){.currency-button{padding:6px 10px;font-size:12px}.currency-symbol{font-size:14px}.currency-code{display:none}.currency-dropdown{min-width:240px;right:-50px}.currency-option{padding:10px 12px}.currency-flag{width:28px;height:28px;font-size:14px}.currency-code-option{font-size:12px}.currency-name{font-size:11px}}@media (max-width: 480px){.currency-button{padding:5px 8px}.currency-dropdown{position:fixed;top:50%;left:50%;right:auto;transform:translate(-50%,-50%);min-width:90vw;max-height:70vh}.currency-list{max-height:60vh}}.mobile-menu-toggle{display:none;position:fixed;top:16px;left:16px;width:44px;height:44px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;align-items:center;justify-content:center;color:var(--text-primary);z-index:500;transition:all var(--fast) ease;box-shadow:var(--shadow-md)}.mobile-menu-toggle:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 12px var(--accent-glow)}.mobile-menu-toggle:active{transform:scale(.95)}.sidebar-wrapper{position:relative;transition:all var(--mid) ease}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;animation:fadeIn .2s ease;transition:background .2s ease,backdrop-filter .2s ease}.nav-item{text-decoration:none;color:inherit}.nav-item:hover,.nav-item:active,.nav-item:visited{text-decoration:none}@media (min-width: 1920px){.sidebar{width:280px}.layout-content{padding:40px}.navbar{padding:0 40px}.page-title{font-size:32px}.summary-cards-grid,.summary-grid{grid-template-columns:repeat(4,1fr)}.charts-grid{grid-template-columns:repeat(2,1fr)}.card{padding:28px}}@media (min-width: 1440px) and (max-width: 1919px){.summary-cards-grid,.summary-grid{grid-template-columns:repeat(3,1fr)}.layout-content{padding:32px}}@media (min-width: 1200px){.summary-cards-grid,.summary-grid{grid-template-columns:repeat(3,1fr);gap:16px}.insights-grid{grid-template-columns:repeat(2,1fr)}.charts-grid{grid-template-columns:1.6fr 1fr}}@media (max-width: 1199px){.navbar{padding:0 28px}.sidebar{width:240px}.summary-cards-grid,.summary-grid{grid-template-columns:repeat(2,1fr);gap:14px}.charts-grid,.insights-grid{grid-template-columns:1fr}.page-title{font-size:24px}.layout-content{padding:24px}}@media (max-width: 1023px) and (min-width: 900px){.sidebar-wrapper{position:fixed;left:0;top:0;height:100vh;z-index:300;width:220px}.sidebar{width:100%;height:100%;transform:translate(-100%);transition:transform var(--mid) var(--ease);box-shadow:2px 0 8px #0000001a}.sidebar-wrapper.open .sidebar{transform:translate(0)}.layout .sidebar-overlay{display:none}.layout .sidebar-wrapper.open~.sidebar-overlay{display:block}.mobile-menu-toggle{display:flex}.navbar{padding:0 60px 0 20px}.navbar-title{font-size:18px}.summary-cards-grid,.summary-grid{grid-template-columns:repeat(2,1fr)}.page-title{font-size:22px}.layout-content{padding:20px}}@media (max-width: 899px){.mobile-menu-toggle{display:flex}.sidebar-wrapper{position:fixed;left:0;top:0;height:100vh;z-index:300;width:220px}.sidebar{width:100%;height:100%;transform:translate(-100%);transition:transform var(--mid) var(--ease);box-shadow:2px 0 8px #0000001a}.sidebar-wrapper.open .sidebar{transform:translate(0)}.sidebar-wrapper.open~.sidebar-overlay{display:block}.layout .sidebar-overlay{display:none}.navbar{padding:0 60px 0 16px}.navbar-title{font-size:17px}.summary-cards-grid,.summary-grid{grid-template-columns:1fr 1fr;gap:12px}.charts-grid,.insights-grid{grid-template-columns:1fr}.page-title{font-size:24px}.layout-content{padding:18px}}@media (max-width: 767px){.mobile-menu-toggle{display:flex;width:42px;height:42px;top:14px;left:14px}.layout-content{padding:80px 16px 16px}.navbar{padding:0 58px 0 64px;height:56px}.navbar-content{gap:10px}.navbar-title{font-size:16px}.navbar-subtitle{font-size:11px;display:none}.page-title{font-size:22px}.page-subtitle{font-size:12px}.summary-cards-grid,.summary-grid{grid-template-columns:1fr;gap:12px}.summary-card{padding:18px 20px}.summary-value,.summary-card-amount{font-size:24px}.charts-grid,.insights-grid,.form-row{grid-template-columns:1fr}.filter-bar,.filter-row{flex-direction:column;gap:10px}.filter-input-group,.filter-select{min-width:unset;flex:1;width:100%}.transaction-item{flex-direction:column;align-items:flex-start;gap:10px}.transaction-item-right{width:100%;margin-left:0;justify-content:space-between}.transaction-amount{min-width:auto}.modal-box,.modal{border-radius:var(--r-lg);max-width:95vw;width:100%}.navbar-actions{gap:6px}.role-label{display:none}.role-select{font-size:11px;padding:5px 25px 5px 8px}.card{padding:16px}.btn{padding:8px 12px;font-size:12px}.btn-sm{padding:5px 10px;font-size:11px}}@media (max-width: 599px){.mobile-menu-toggle{width:40px;height:40px;top:12px;left:12px}.layout-content{padding:70px 14px 14px}.navbar{padding:0 54px 0 60px;height:54px}.navbar-title{font-size:15px}.page-title{font-size:20px}.page-subtitle{font-size:12px}.summary-card{padding:16px}.summary-value,.summary-card-amount{font-size:22px}.summary-icon{width:32px;height:32px;margin-bottom:10px}.summary-label,.summary-card-title{font-size:10px}.summary-change,.summary-card-change{font-size:10px;margin-top:6px}.transaction-category{font-size:12px}.transaction-description{font-size:11px}.card{padding:14px}.card-title{font-size:10px}.btn{padding:7px 12px;font-size:11px;gap:4px}.modal{max-width:90vw}.modal-header{padding:18px 20px 16px}.modal-body{padding:18px}.modal-footer{padding:14px 16px}}@media (max-width: 479px){.mobile-menu-toggle{width:38px;height:38px;top:10px;left:10px}.layout-content{padding:66px 12px 12px}.navbar{padding:0 50px 0 56px;height:52px}.navbar-title{font-size:14px}.navbar-content{gap:6px}.page-title{font-size:18px}.page-subtitle{display:none}.page-header{margin-bottom:2px}.page-wrapper{gap:16px}.summary-card{padding:14px}.summary-value,.summary-card-amount{font-size:20px}.summary-icon,.summary-card-icon{width:30px;height:30px;margin-bottom:8px}.summary-label,.summary-card-title{font-size:9px}.summary-change,.summary-card-change{font-size:9px;margin-top:4px}.transaction-item{padding:12px;gap:8px}.transaction-category{font-size:11px}.transaction-description,.transaction-date{font-size:10px}.transaction-amount{font-size:12px}.card{padding:12px}.card-title{font-size:9px;margin-bottom:2px}.btn{padding:6px 10px;font-size:10px}.btn-icon,.icon-btn{width:32px;height:32px}.btn-icon-sm{width:24px;height:24px}.modal{max-width:88vw}.modal-header{padding:16px 18px 14px}.modal-body{padding:16px}.modal-footer{padding:12px 14px;gap:8px}.modal-title{font-size:14px}.form-input,.form-select{font-size:12px;padding:7px 10px}.form-group label{font-size:11px;margin-bottom:4px}.role-select{font-size:10px;padding:4px 20px 4px 6px}}@media (max-width: 359px){.mobile-menu-toggle{width:36px;height:36px;top:8px;left:8px}.layout{font-size:12px}.layout-content{padding:62px 10px 10px}.navbar{padding:0 46px 0 52px;height:50px}.navbar-title{font-size:13px}.page-title{font-size:16px}.page-subtitle{display:none}.summary-card{padding:12px}.summary-value,.summary-card-amount{font-size:18px}.summary-icon{width:28px;height:28px;margin-bottom:6px}.summary-label,.summary-card-title{font-size:8px}.transaction-item{padding:10px;gap:6px}.transaction-category{font-size:10px}.transaction-description{font-size:9px}.transaction-amount{font-size:11px}.card{padding:10px}.btn{padding:5px 8px;font-size:9px}.card-title{font-size:8px}.modal{max-width:85vw}.modal-header{padding:14px 16px 12px}.modal-body{padding:14px}.modal-footer{padding:10px 12px}.modal-title{font-size:13px}.form-input,.form-select{font-size:11px;padding:6px 8px}.role-select{font-size:9px}}@supports (padding: max(0px)){.navbar{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}.layout-content{padding-bottom:max(16px,env(safe-area-inset-bottom))}}@media (max-height: 600px) and (orientation: landscape){.navbar{height:48px}.layout-content{padding:12px}.page-title{font-size:18px;margin-bottom:2px}.summary-card{padding:12px}}@media (min-device-pixel-ratio: 2) and (max-width: 600px){body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.mobile-menu-toggle{box-shadow:0 2px 4px #0000001a}}@media (orientation: portrait) and (max-width: 600px){.layout-content{padding-top:80px}}@media (orientation: landscape) and (max-height: 600px){.navbar{height:46px;padding:0 50px 0 12px}.layout-content{padding:10px 12px}.page-title{font-size:16px}.summary-cards-grid{gap:8px}.summary-card{padding:12px 14px}.summary-value{font-size:18px}}@media (hover: none) and (pointer: coarse){.btn,.nav-item,.card{min-height:44px;min-width:44px}.btn-icon,.icon-btn{min-width:44px;min-height:44px}}.export-button-group{display:flex;gap:.75rem;animation:slideInRight .3s ease}.export-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--bg-secondary);border:2px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-weight:500;font-size:13px;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden}.export-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transform:translate(-100%);transition:transform .6s ease}.export-btn:hover{border-color:var(--primary);background:var(--primary);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #6366f133}.export-btn:hover:before{transform:translate(100%)}.export-btn:active{transform:translateY(0)}[data-theme=dark] .export-btn{background:var(--bg-secondary);border-color:var(--border);color:var(--text-primary)}[data-theme=dark] .export-btn:hover{border-color:var(--primary);background:var(--primary);color:#fff}.analytics-container{padding:24px;background:var(--bg-secondary);border-radius:12px;margin-bottom:24px;overflow:hidden;overflow-x:hidden}.analytics-header{margin-bottom:32px}.analytics-header h2{font-size:24px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.analytics-subtitle{color:var(--text-secondary);font-size:14px}.prediction-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-bottom:32px}.prediction-card{display:flex;align-items:flex-start;gap:16px;padding:20px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;transition:all var(--mid) ease;overflow:hidden;min-width:0}.prediction-card:hover{border-color:var(--primary);box-shadow:0 4px 12px #6366f11a;transform:translateY(-2px)}.prediction-icon{width:50px;height:50px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff}.prediction-icon.income{background:linear-gradient(135deg,#10b981,#059669)}.prediction-icon.expense{background:linear-gradient(135deg,#f43f5e,#e11d48)}.prediction-icon.growth{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.prediction-icon.confidence{background:linear-gradient(135deg,#f59e0b,#d97706)}.prediction-content{flex:1;min-width:0;overflow:hidden}.prediction-label{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:6px;font-weight:500}.prediction-amount{font-size:24px;font-weight:700;color:var(--text-primary);font-family:DM Mono,monospace;margin-bottom:4px;word-break:break-word;overflow-wrap:break-word;min-width:0;max-width:100%}.prediction-meta{font-size:12px;color:var(--text-secondary)}.trend-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600;margin-left:8px}.trend-badge.increasing{background-color:#f43f5e1a;color:#f43f5e}.trend-badge.decreasing{background-color:#10b9811a;color:#10b981}.analytics-section{margin-bottom:32px;padding:20px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px}.analytics-section h3{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:20px}.chart-wrapper{width:100%;height:auto}.category-trends{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}.trend-card{padding:16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;transition:all var(--mid) ease;overflow:hidden;min-width:0}.trend-card:hover{border-color:var(--primary);box-shadow:0 2px 8px #6366f114;transform:translateY(-2px)}.trend-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.trend-rank{width:28px;height:28px;background:var(--primary-light);color:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px}.trend-header h4{flex:1;margin:0;color:var(--text-primary);font-size:14px;font-weight:500}.trend-indicator{padding:4px 8px;background:var(--bg-primary);border-radius:6px;font-size:12px;font-weight:600;white-space:nowrap}.trend-indicator.up{color:#f43f5e}.trend-indicator.down{color:#10b981}.trend-value{text-align:center}.trend-amount{font-size:18px;font-weight:700;color:var(--text-primary);font-family:DM Mono,monospace;margin:0 0 4px;word-break:break-word;overflow-wrap:break-word;min-width:0}.trend-desc{font-size:12px;color:var(--text-secondary);margin:0}:root[data-theme=dark] .prediction-card,:root[data-theme=dark] .analytics-section,:root[data-theme=dark] .trend-card{background:var(--bg-primary);border-color:var(--border-color)}:root[data-theme=dark] .prediction-card:hover,:root[data-theme=dark] .trend-card:hover,:root[data-theme=dark] .insight:hover{border-color:var(--primary)}@media (max-width: 768px){.analytics-container{padding:16px}.analytics-header h2{font-size:20px}.prediction-cards{grid-template-columns:1fr}.analytics-section{padding:16px}.analytics-section h3{font-size:16px;margin-bottom:16px}.category-trends{grid-template-columns:repeat(2,1fr)}.prediction-amount{font-size:20px}}@media (max-width: 480px){.analytics-container{padding:12px}.analytics-header h2{font-size:18px}.prediction-amount{font-size:16px}.category-trends{grid-template-columns:1fr}.trend-header{flex-direction:column;align-items:flex-start}.trend-indicator{width:100%;text-align:center}.prediction-card{flex-direction:column;align-items:center;text-align:center}.prediction-icon{width:40px;height:40px}.prediction-amount{font-size:18px}}:root{--accent: #0ea5e9;--accent-dark: #0284c7;--accent-glow: rgba(14, 165, 233, .25);--accent-dim: rgba(14, 165, 233, .08);--income: #10b981;--income-bg: rgba(16, 185, 129, .1);--expense: #f43f5e;--expense-bg: rgba(244, 63, 94, .1);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .1);--info: #6366f1;--info-bg: rgba(99, 102, 241, .1);--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 20px;--r-full: 9999px;--ease: cubic-bezier(.16, 1, .3, 1);--fast: .15s;--mid: .25s;--slow: .4s}.theme-light,:root{--bg-base: #f0f4f8;--bg-surface: #ffffff;--bg-card: #ffffff;--bg-card-hover:#f7fafd;--bg-input: #f0f4f8;--bg-inset: #e8edf3;--border: rgba(0, 0, 0, .07);--border-strong:rgba(0, 0, 0, .13);--text-primary: #0d1117;--text-secondary: #4a5568;--text-muted: #94a3b8;--shadow-sm: 0 1px 3px rgba(0,0,0,.05), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.07), 0 2px 6px rgba(0,0,0,.05);--shadow-lg: 0 12px 32px rgba(0,0,0,.1), 0 4px 12px rgba(0,0,0,.06);--shadow-xl: 0 24px 48px rgba(0,0,0,.12), 0 8px 20px rgba(0,0,0,.08);--scrollbar-thumb: #cbd5e1}.theme-dark{--bg-base: #0f1117;--bg-surface: #161b22;--bg-card: #1c2230;--bg-card-hover:#222b3a;--bg-input: #161b22;--bg-inset: #0f1117;--border: rgba(255,255,255,.07);--border-strong:rgba(255,255,255,.13);--text-primary: #f0f6fc;--text-secondary: #8b9db8;--text-muted: #4d6175;--shadow-sm: 0 1px 3px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.4);--shadow-lg: 0 12px 32px rgba(0,0,0,.5);--shadow-xl: 0 24px 48px rgba(0,0,0,.6);--scrollbar-thumb: #2d3748}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%}body{font-family:Outfit,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;line-height:1.5;color:var(--text-primary);background:var(--bg-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background var(--mid) ease,color var(--mid) ease}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:var(--r-full);transition:background-color var(--fast) ease}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:240px;flex-shrink:0;background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:20px 0;height:100vh;position:sticky;top:0;z-index:100;transition:transform var(--mid) var(--ease)}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:0 18px 20px;border-bottom:1px solid var(--border);margin-bottom:12px}.logo-icon{width:34px;height:34px;background:var(--accent);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px var(--accent-glow)}.logo-text{font-family:Syne,sans-serif;font-weight:800;font-size:17px;color:var(--text-primary);letter-spacing:-.4px;line-height:1}.logo-text span{color:var(--accent)}.nav-section-label{font-size:10px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:var(--text-muted);padding:8px 18px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 18px;margin:2px 10px;border-radius:var(--r-md);cursor:pointer;transition:background var(--fast) ease,color var(--fast) ease;font-size:13.5px;font-weight:500;color:var(--text-secondary);border:none;background:transparent;width:calc(100% - 20px);text-align:left;font-family:inherit;position:relative}.nav-item .nav-icon{flex-shrink:0;opacity:.6;transition:opacity var(--fast) ease}.nav-item:hover{background:var(--accent-dim);color:var(--text-primary)}.nav-item:hover .nav-icon{opacity:.9}.nav-item.active{background:var(--accent-dim);color:var(--accent);font-weight:600}.nav-item.active .nav-icon{opacity:1}.nav-item.active:before{content:"";position:absolute;left:-10px;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--accent);border-radius:0 var(--r-full) var(--r-full) 0}.sidebar-footer{margin-top:auto;padding:14px 18px 0;border-top:1px solid var(--border);text-align:left}.layout-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.navbar{background:var(--bg-surface);border-bottom:1px solid var(--border);padding:0 28px;height:64px;flex-shrink:0;position:sticky;top:0;z-index:50;box-shadow:var(--shadow-sm)}.navbar-content{display:flex;align-items:center;justify-content:space-between;height:100%;gap:20px}.navbar-title-section{flex:1;min-width:0}.navbar-title{font-family:Syne,sans-serif;font-size:19px;font-weight:800;color:var(--text-primary);letter-spacing:-.4px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.navbar-subtitle{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.navbar-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}.role-switcher{display:flex;align-items:center;gap:7px}.role-label{font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--text-muted)}.role-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;padding:6px 30px 6px 10px;border:1px solid var(--border-strong);border-radius:var(--r-full);background:var(--bg-card) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2394a3b8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 10px center;color:var(--text-primary);font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--fast) ease}.role-select:hover,.role-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.layout-content{flex:1;overflow-y:auto;padding:28px}.page-wrapper{display:flex;flex-direction:column;gap:20px;animation:fadeUp var(--slow) var(--ease) both}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.page-header{margin-bottom:4px}.page-title{font-family:Syne,sans-serif;font-size:26px;font-weight:800;color:var(--text-primary);letter-spacing:-.5px;line-height:1.2}.page-subtitle{font-size:13px;color:var(--text-secondary);margin-top:4px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:22px;transition:all var(--mid) ease}.card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-title{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);margin-bottom:4px}.summary-cards-grid,.summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.summary-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px 22px;position:relative;overflow:hidden;transition:transform var(--mid) var(--ease),box-shadow var(--mid) ease,border-color var(--mid) ease;cursor:default}.summary-card:after{content:"";position:absolute;top:-24px;right:-24px;width:90px;height:90px;border-radius:50%;opacity:.06;transition:opacity var(--mid) ease,transform var(--mid) ease}.summary-card.balance:after{background:var(--info)}.summary-card.income:after{background:var(--income)}.summary-card.expense:after{background:var(--expense)}.summary-card.card-primary{border-color:#6366f133}.summary-card.card-success{border-color:#10b98133}.summary-card.card-danger{border-color:#f43f5e33}.summary-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--border-strong)}.summary-card:hover .summary-icon{transform:scale(1.1)}.summary-card:hover:after{opacity:.12;transform:scale(1.1)}.summary-icon{width:38px;height:38px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;margin-bottom:14px;transition:all var(--fast) ease}.summary-label,.summary-card-title{font-size:10.5px;font-weight:700;letter-spacing:1.1px;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}.summary-value,.summary-card-amount{font-family:DM Mono,monospace;font-size:26px;font-weight:500;letter-spacing:-.5px;line-height:1;color:var(--text-primary)}.summary-change,.summary-card-change{font-size:11px;margin-top:8px;display:flex;align-items:center;gap:4px;color:var(--text-secondary)}.summary-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.summary-card-icon{opacity:.7}.charts-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 16px;border-radius:var(--r-md);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--fast) ease;border:none;outline:none;white-space:nowrap;text-decoration:none}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 2px 8px var(--accent-glow)}.btn-primary:hover{background:var(--accent-dark);transform:translateY(-1px);box-shadow:0 6px 20px var(--accent-glow)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-strong)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.btn-ghost{background:transparent;color:var(--text-secondary);transition:all var(--fast) ease}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-input);transform:translateY(-1px)}.btn-sm{padding:5px 10px;font-size:12px;border-radius:var(--r-sm)}.btn-md{padding:10px 18px;font-size:13px}.btn-icon,.icon-btn{width:36px;height:36px;padding:0;border-radius:var(--r-md);border:1px solid var(--border);background:var(--bg-card);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all var(--fast) ease}.btn-icon:hover,.icon-btn:hover{border-color:var(--accent);color:var(--accent)}.btn-icon-sm{width:28px;height:28px;padding:0;border-radius:var(--r-sm);border:none;background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);transition:all var(--fast) ease}.btn-icon-sm:hover{background:var(--bg-input);color:var(--expense)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:overlayIn var(--fast) ease both;padding:20px}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.modal,.modal-box{background:var(--bg-card);border:1px solid var(--border-strong);border-radius:var(--r-xl);box-shadow:var(--shadow-xl);width:100%;max-width:460px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;animation:modalIn var(--mid) var(--ease) both}@keyframes modalIn{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-sm{max-width:380px}.modal-md{max-width:460px}.modal-lg{max-width:680px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:22px 24px 18px;border-bottom:1px solid var(--border);gap:16px;flex-shrink:0}.modal-title{font-family:Syne,sans-serif;font-size:17px;font-weight:800;color:var(--text-primary);letter-spacing:-.3px}.modal-close{width:30px;height:30px;border-radius:var(--r-md);border:none;background:var(--bg-input);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all var(--fast) ease;flex-shrink:0}.modal-close:hover{background:var(--expense-bg);color:var(--expense)}.modal-body{padding:22px 24px;flex:1}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;flex-shrink:0}.form-group{margin-bottom:16px}.form-group label,.form-label{display:block;font-size:10.5px;font-weight:700;letter-spacing:.9px;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px;transition:color var(--fast) ease}.form-input,.form-select,.select-input,.search-input{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-md);padding:10px 14px;font-size:13px;color:var(--text-primary);font-family:inherit;outline:none;transition:border-color var(--fast) ease,box-shadow var(--fast) ease}.form-input:focus,.form-select:focus,.select-input:focus,.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-input::placeholder,.search-input::placeholder{color:var(--text-muted)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.amount-input-wrapper{display:flex;align-items:center;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-md);padding:0;transition:border-color var(--fast) ease,box-shadow var(--fast) ease}.amount-input-wrapper:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.currency-prefix{padding:10px 8px 10px 14px;font-size:14px;font-weight:600;color:var(--text-secondary);white-space:nowrap;-webkit-user-select:none;user-select:none;border-right:1px solid var(--border)}.amount-input-wrapper input{flex:1;background:transparent;border:none;padding:10px 14px 10px 8px;font-size:13px;color:var(--text-primary);font-family:inherit;outline:none}.amount-input-wrapper input::placeholder{color:var(--text-muted)}.filter-bar,.filter-row{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap;align-items:center}.filter-card{margin-bottom:16px}.filter-title{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:14px}.filter-group{display:flex;flex-direction:column;gap:12px}.filter-input-group{flex:1;min-width:200px;display:flex;align-items:center;gap:8px;padding:0 12px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-input);transition:border-color var(--fast) ease}.filter-input-group:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.filter-input-group svg{color:var(--text-muted);flex-shrink:0}.filter-input{flex:1;border:none;background:transparent;padding:9px 0;font-size:13px;color:var(--text-primary);outline:none;font-family:inherit}.filter-input::placeholder{color:var(--text-muted)}.filter-select,.select-input{flex:1;min-width:140px;width:auto;cursor:pointer}.search-wrap{position:relative;flex:1;min-width:200px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-input{padding-left:36px}.transaction-list{display:flex;flex-direction:column;gap:10px}.transaction-item{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);transition:border-color var(--fast) ease,box-shadow var(--fast) ease,transform var(--fast) ease}.transaction-item:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translate(2px)}.transaction-item.income{border-left:3px solid var(--income)}.transaction-item.expense{border-left:3px solid var(--expense)}.transaction-item-left{flex:1;min-width:0}.transaction-category{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.transaction-description{font-size:12px;color:var(--text-secondary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.transaction-date{font-size:11px;color:var(--text-muted);font-family:DM Mono,monospace}.transaction-item-right{display:flex;align-items:center;gap:12px;flex-shrink:0;margin-left:16px}.transaction-amount{font-family:DM Mono,monospace;font-size:14px;font-weight:600;min-width:90px;text-align:right}.amount-income{color:var(--income)}.amount-expense{color:var(--expense)}.table-scroll{overflow-x:auto}.table-scroll::-webkit-scrollbar{height:4px}.table,.tx-table{width:100%;border-collapse:collapse;font-size:13px}.table thead,.tx-table thead{border-bottom:1px solid var(--border)}.table th,.tx-table th{padding:10px 16px;text-align:left;font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:color var(--fast) ease}.table th:hover,.tx-table th:hover{color:var(--text-secondary)}.tx-table th.sorted{color:var(--accent)}.table tbody tr,.tx-row{border-bottom:1px solid var(--border);transition:background var(--fast) ease}.table tbody tr:last-child,.tx-row:last-child{border-bottom:none}.table tbody tr:hover,.tx-row:hover{background:var(--bg-card-hover)}.table td,.tx-row td{padding:12px 16px;color:var(--text-primary);vertical-align:middle}.table th[align=right],.table td[align=right]{text-align:right}.table th[align=center],.table td[align=center]{text-align:center}.tx-desc{font-weight:500;color:var(--text-primary)}.tx-date{font-family:DM Mono,monospace;font-size:12px;color:var(--text-secondary)}.tx-amount{font-family:DM Mono,monospace;font-weight:500;white-space:nowrap}.tx-amount.income{color:var(--income)}.tx-amount.expense{color:var(--expense)}.category-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:var(--r-sm);font-size:11px;font-weight:600;background:var(--accent-dim);color:var(--text-secondary);transition:all var(--fast) ease;cursor:default}.category-chip:hover{background:var(--accent-glow);color:var(--text-primary)}.type-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:var(--r-full);font-size:11px;font-weight:600;letter-spacing:.3px}.type-badge.income{background:var(--income-bg);color:var(--income)}.type-badge.expense{background:var(--expense-bg);color:var(--expense)}.action-btn{padding:5px 9px;border-radius:var(--r-sm);border:1px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;font-size:12px;font-family:inherit;transition:all var(--fast) ease;display:inline-flex;align-items:center;gap:4px}.action-btn:hover{border-color:var(--border-strong);color:var(--text-primary)}.action-btn.danger:hover{border-color:var(--expense);color:var(--expense);background:var(--expense-bg)}.insights-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.insight-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px 22px;display:flex;align-items:center;gap:16px;transition:border-color var(--fast) ease,box-shadow var(--fast) ease}.insight-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md)}.insight-card.insight-primary{background:linear-gradient(135deg,var(--info),#818cf8);color:#fff;border:none}.insight-card.insight-success{background:linear-gradient(135deg,var(--income),#34d399);color:#fff;border:none}.insight-card.insight-danger{background:linear-gradient(135deg,var(--expense),#fb7185);color:#fff;border:none}.insight-icon{width:46px;height:46px;border-radius:var(--r-md);background:#ffffff2e;display:flex;align-items:center;justify-content:center;flex-shrink:0}.insight-content{flex:1}.insight-title{font-family:Syne,sans-serif;font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:2px}.insight-card.insight-primary .insight-title,.insight-card.insight-success .insight-title,.insight-card.insight-danger .insight-title{color:#ffffffd9;font-size:11px;text-transform:uppercase;letter-spacing:.8px;font-family:Outfit,sans-serif;font-weight:600}.insight-sub,.insight-secondary{font-size:12px;color:var(--text-secondary);margin-bottom:14px}.insight-value{font-family:DM Mono,monospace;font-size:22px;font-weight:500;margin-bottom:4px}.stat-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}.stat-row:last-child{border-bottom:none}.stat-label{font-size:13px;color:var(--text-secondary);display:flex;align-items:center;gap:8px}.stat-value{font-family:DM Mono,monospace;font-size:13px;font-weight:500;color:var(--text-primary)}.progress-bar{height:5px;background:var(--border);border-radius:var(--r-full);overflow:hidden;margin-top:6px}.progress-fill{height:100%;border-radius:var(--r-full);transition:width .6s var(--ease)}.type-toggle{display:flex;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-md);padding:4px;gap:4px}.type-toggle-btn{flex:1;padding:8px;border-radius:var(--r-sm);border:none;background:transparent;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;color:var(--text-muted);transition:all var(--fast) ease}.type-toggle-btn.active.income{background:var(--income-bg);color:var(--income)}.type-toggle-btn.active.expense{background:var(--expense-bg);color:var(--expense)}.role-badge{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:var(--r-full);font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--border-strong);background:var(--bg-card);color:var(--text-primary);transition:all var(--fast) ease}.role-badge:hover{border-color:var(--accent)}.role-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.role-dot.admin{background:var(--accent);box-shadow:0 0 6px var(--accent-glow)}.role-dot.viewer{background:var(--warning);box-shadow:0 0 6px var(--warning-bg)}.role-dropdown{position:relative}.role-dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:var(--r-lg);padding:6px;min-width:160px;z-index:200;box-shadow:var(--shadow-lg);animation:modalIn var(--mid) var(--ease) both}.role-option{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:var(--r-md);cursor:pointer;font-size:13px;font-weight:500;color:var(--text-secondary);transition:all var(--fast) ease;border:none;background:transparent;width:100%;text-align:left;font-family:inherit}.role-option:hover{background:var(--accent-dim);color:var(--text-primary)}.role-option.active{color:var(--accent);font-weight:600}.chart-tooltip{background:var(--bg-card);border:1px solid var(--border-strong);border-radius:var(--r-md);padding:10px 14px;font-size:12px;box-shadow:var(--shadow-md)}.chart-tooltip-title{font-family:Syne,sans-serif;font-size:12px;font-weight:700;color:var(--text-primary);margin-bottom:6px}.chart-tooltip-row{display:flex;justify-content:space-between;gap:16px;margin-top:3px}.chart-tooltip-label{color:var(--text-secondary)}.chart-tooltip-val{font-family:DM Mono,monospace;font-weight:500;color:var(--text-primary)}.accent-line{width:28px;height:3px;background:var(--accent);border-radius:var(--r-full);margin-top:6px;margin-bottom:18px}.viewer-banner{background:var(--warning-bg);border:1px solid var(--warning);border-radius:var(--r-md);padding:10px 16px;display:flex;align-items:center;gap:10px;font-size:13px;color:var(--warning);margin-bottom:20px}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty-state-icon{font-size:38px;margin-bottom:10px;opacity:.4}.empty-state-text{font-size:14px;color:var(--text-secondary)}.recharts-tooltip-wrapper .recharts-default-tooltip{background:var(--bg-card)!important;border:1px solid var(--border-strong)!important;border-radius:var(--r-md)!important;font-family:Outfit,sans-serif!important;font-size:12px!important}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.shimmer{background:linear-gradient(90deg,var(--bg-input) 25%,var(--bg-card-hover) 50%,var(--bg-input) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--r-md)}@media (min-width: 1920px){.summary-cards-grid,.summary-grid{grid-template-columns:repeat(4,1fr);gap:18px}.insights-grid{grid-template-columns:repeat(3,1fr)}.charts-grid{grid-template-columns:repeat(2,1fr);gap:18px}}@media (min-width: 1440px) and (max-width: 1919px){.summary-cards-grid,.summary-grid{grid-template-columns:repeat(3,1fr);gap:16px}.insights-grid{grid-template-columns:repeat(2,1fr)}.charts-grid{grid-template-columns:1.6fr 1fr}}@media (min-width: 1200px){.summary-cards-grid,.summary-grid{grid-template-columns:repeat(3,1fr)}.insights-grid{grid-template-columns:repeat(2,1fr)}.charts-grid{grid-template-columns:1.6fr 1fr}}@media (max-width: 1199px){.summary-cards-grid,.summary-grid{grid-template-columns:repeat(2,1fr)}.charts-grid,.insights-grid{grid-template-columns:1fr}}@media (max-width: 1023px){.summary-cards-grid,.summary-grid{grid-template-columns:repeat(2,1fr)}.charts-grid,.insights-grid{grid-template-columns:1fr}}@media (max-width: 899px){.summary-cards-grid,.summary-grid{grid-template-columns:1fr 1fr}.charts-grid,.insights-grid{grid-template-columns:1fr}}@media (max-width: 767px){.summary-cards-grid,.summary-grid,.charts-grid{grid-template-columns:1fr}.insights-grid{grid-template-columns:1fr;gap:12px}.insight-card{padding:16px;flex-direction:column;align-items:flex-start;gap:12px}.insight-title{font-size:13px}.insight-sub{font-size:11px}.table-scroll table{font-size:12px}.table th,.tx-table th{padding:8px 12px;font-size:9px}.table td,.tx-row td{padding:10px 12px}}@media (max-width: 599px){.summary-cards-grid,.summary-grid{grid-template-columns:1fr;gap:12px}.charts-grid{grid-template-columns:1fr}.insights-grid{grid-template-columns:1fr;gap:12px}.insight-card{padding:14px;flex-direction:column;align-items:flex-start;gap:10px}.insight-title{font-size:12px}.insight-sub{font-size:10px}.transaction-item{flex-direction:column;align-items:flex-start;padding:12px}.transaction-item-right{width:100%;margin-left:0;margin-top:10px;justify-content:space-between}.transaction-amount{min-width:auto;font-size:13px}.transaction-category{font-size:12px}.transaction-description,.table-scroll table{font-size:11px}.table th,.tx-table th{padding:8px 10px;font-size:8px}.table td,.tx-row td{padding:8px 10px}}@media (max-width: 479px){.summary-cards-grid,.summary-grid{grid-template-columns:1fr;gap:10px}.transaction-item{padding:11px;gap:8px}.transaction-category{font-size:11px}.transaction-description,.transaction-date{font-size:10px}.transaction-amount{font-size:12px}.empty-state{padding:40px 16px}.empty-state-icon{font-size:32px}.table-scroll{overflow-x:auto}.table-scroll table{font-size:10px;min-width:280px}}@media (max-width: 359px){.summary-cards-grid,.summary-grid{grid-template-columns:1fr;gap:8px}.transaction-item{padding:10px}.transaction-amount{font-size:11px}.empty-state{padding:30px 12px}.empty-state-icon{font-size:28px;margin-bottom:8px}.table-scroll table{font-size:9px}}@media (orientation: landscape) and (max-height: 600px){.summary-cards-grid,.summary-grid{grid-template-columns:repeat(2,1fr);gap:8px}.insights-grid,.charts-grid{grid-template-columns:repeat(2,1fr)}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.animate-fade{animation:fadeIn .3s ease}.animate-slide-up{animation:slideInUp .3s ease}.animate-slide-down{animation:slideInDown .3s ease}.animate-slide-left{animation:slideInLeft .3s ease}.animate-slide-right{animation:slideInRight .3s ease}.animate-scale{animation:scaleIn .3s ease}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-spin{animation:spin 1s linear infinite}.animate-bounce{animation:bounce .5s ease}.transition-all{transition:all .3s ease}.transition-colors{transition:color .3s ease,background-color .3s ease,border-color .3s ease}.transition-transform{transition:transform .3s ease}.hover-lift{transition:transform .3s ease,box-shadow .3s ease}.hover-lift:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.hover-scale{transition:transform .3s ease}.hover-scale:hover{transform:scale(1.05)}.hover-glow{transition:box-shadow .3s ease}.hover-glow:hover{box-shadow:0 0 20px #6366f14d}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 0%,var(--bg-secondary) 50%,var(--bg-tertiary) 100%);background-size:1000px 100%;animation:shimmer 2s infinite;border-radius:var(--radius-md)}[data-theme=dark]{--primary: #818cf8;--primary-light: #a5b4fc;--primary-dark: #6366f1;--secondary: #a78bfa;--accent: #f472b6;--success: #34d399;--income: #34d399;--expense: #f87171;--danger: #f87171;--warning: #fbbf24;--bg-primary: #1a1a2e;--bg-secondary: #16213e;--bg-tertiary: #0f3460;--border: #2d3e5f;--text-primary: #e0e0e0;--text-secondary: #b0b0b0;--text-muted: #7a7a7a;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5);color-scheme:dark}[data-theme=dark] *{transition:background-color .2s ease,color .2s ease,border-color .2s ease}[data-theme=dark] body{background-color:var(--bg-primary);color:var(--text-primary)}[data-theme=dark] input,[data-theme=dark] select,[data-theme=dark] textarea{background-color:var(--bg-secondary);color:var(--text-primary);border-color:var(--border)}[data-theme=dark] input::placeholder,[data-theme=dark] textarea::placeholder{color:var(--text-muted)}[data-theme=dark] input:focus,[data-theme=dark] select:focus,[data-theme=dark] textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #818cf826;background-color:var(--bg-tertiary)}[data-theme=dark] .card,[data-theme=dark] .container,[data-theme=dark] .modal,[data-theme=dark] .dropdown-menu{background-color:var(--bg-secondary);border-color:var(--border)}[data-theme=dark] button{transition:all .2s ease}[data-theme=dark] .btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px #818cf84d}[data-theme=dark] .btn-primary:hover{background:var(--primary-dark);box-shadow:0 6px 20px #818cf866}[data-theme=dark] .btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid rgba(255,255,255,.15)}[data-theme=dark] .btn-secondary:hover{background:var(--bg-tertiary);border-color:var(--secondary);color:var(--secondary)}[data-theme=dark] .btn-ghost{color:var(--text-secondary)}[data-theme=dark] .btn-ghost:hover{color:var(--text-primary);background:var(--bg-secondary)}[data-theme=dark] table{background-color:var(--bg-secondary);border-color:var(--border)}[data-theme=dark] table thead,[data-theme=dark] table tbody tr:hover{background-color:var(--bg-tertiary)}[data-theme=dark] table tbody tr{border-color:var(--border)}[data-theme=dark] code{background-color:var(--bg-tertiary);color:var(--primary-light)}[data-theme=dark] pre{background-color:var(--bg-tertiary);color:var(--text-primary)}[data-theme=dark] ::-webkit-scrollbar{width:8px;height:8px}[data-theme=dark] ::-webkit-scrollbar-track{background:var(--bg-secondary)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:var(--primary)}[data-theme=dark] .form-group label{color:var(--text-primary)}[data-theme=dark] .form-check-input{background-color:var(--bg-tertiary);border-color:var(--border)}[data-theme=dark] .form-check-input:checked{background-color:var(--primary);border-color:var(--primary)}[data-theme=dark] .badge{background-color:var(--primary);color:var(--bg-primary)}[data-theme=dark] .badge.secondary{background-color:var(--secondary);color:var(--bg-primary)}[data-theme=dark] .label{background-color:var(--bg-tertiary);color:var(--text-primary);border-color:var(--primary)}[data-theme=dark] .alert{background-color:var(--bg-tertiary);border-color:var(--border);color:var(--text-primary)}[data-theme=dark] .alert.success{background-color:#34d39926;border-color:var(--success);color:#34d399}[data-theme=dark] .alert.error{background-color:#f8717126;border-color:var(--danger);color:#f87171}[data-theme=dark] .alert.warning{background-color:#fbbf2426;border-color:var(--warning);color:#fbbf24}[data-theme=dark] .chart-container{background-color:var(--bg-secondary)}[data-theme=dark] .chart-tooltip{background-color:#0d112ee6;border:1px solid var(--border);color:var(--text-primary)}[data-theme=dark] .chart-tooltip-title{color:var(--text-primary);font-weight:600}[data-theme=dark] .chart-tooltip-row{color:var(--text-secondary)}[data-theme=dark] .chart-tooltip-label{font-weight:500}[data-theme=dark] .dropdown-menu{background-color:var(--bg-secondary);border:1px solid var(--border)}[data-theme=dark] .dropdown-item{color:var(--text-primary)}[data-theme=dark] .dropdown-item:hover{background-color:var(--bg-tertiary)}[data-theme=dark] nav,[data-theme=dark] .navbar{background-color:var(--bg-secondary);border-bottom:1px solid var(--border)}[data-theme=dark] .navbar-title{color:var(--text-primary)}[data-theme=dark] .navbar-subtitle{color:var(--text-muted)}[data-theme=dark] .sidebar{background-color:var(--bg-secondary);border-right:1px solid var(--border)}[data-theme=dark] .sidebar-item{color:var(--text-secondary)}[data-theme=dark] .sidebar-item.active{background-color:var(--bg-tertiary);color:var(--primary)}[data-theme=dark] .logo-text{color:var(--text-primary)}[data-theme=dark] .nav-item{color:var(--text-secondary)}[data-theme=dark] .nav-item:hover{color:var(--text-primary)}[data-theme=dark] .nav-item.active{color:var(--primary)}[data-theme=dark] .modal-overlay{background-color:#000000b3}[data-theme=dark] .modal-content{background-color:var(--bg-secondary)}[data-theme=dark] .modal,[data-theme=dark] .modal-box{background-color:var(--bg-secondary);color:var(--text-primary)}[data-theme=dark] .modal-header{border-bottom-color:var(--border)}[data-theme=dark] .insight-card{background-color:var(--bg-secondary);border-color:var(--border)}[data-theme=dark] .insight-title{color:var(--text-primary)}[data-theme=dark] .insight-sub{color:var(--text-muted)}[data-theme=dark] .insight-value{color:var(--text-primary)}[data-theme=dark] .stat-row{border-bottom-color:var(--border)}[data-theme=dark] .stat-label{color:var(--text-secondary)}[data-theme=dark] .stat-value{color:var(--text-primary)}[data-theme=dark] .summary-card{background-color:var(--bg-secondary);border-color:var(--border)}[data-theme=dark] .summary-card:hover{border-color:var(--border-strong)}[data-theme=dark] .summary-title,[data-theme=dark] .summary-card-title,[data-theme=dark] .summary-label{color:var(--text-muted)}[data-theme=dark] .summary-value,[data-theme=dark] .summary-card-amount{color:var(--text-primary)}[data-theme=dark] .summary-change,[data-theme=dark] .summary-card-change{color:var(--text-secondary)}[data-theme=dark] .text-muted{color:var(--text-muted)!important}[data-theme=dark] .text-secondary{color:var(--text-secondary)!important}[data-theme=dark] .text-primary{color:var(--text-primary)!important}.transaction-item{display:flex;align-items:center;justify-content:space-between;padding:16px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:12px;transition:all .3s ease;animation:slideInUp .3s ease;cursor:default}.transaction-item:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translate(4px)}.transaction-left{display:flex;align-items:center;gap:16px;flex:1}.transaction-icon{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);color:var(--primary);font-weight:600;transition:all .3s ease}.transaction-item:hover .transaction-icon{transform:scale(1.1);background:var(--primary);color:#fff}.transaction-info{display:flex;flex-direction:column;gap:4px}.transaction-description{font-weight:500;color:var(--text-primary)}.transaction-category{font-size:12px;color:var(--text-muted)}.transaction-amount{font-weight:700;font-family:DM Mono,monospace;min-width:100px;text-align:right}.transaction-amount.income{color:var(--income)}.transaction-amount.expense{color:var(--expense)}.transaction-table{width:100%;border-collapse:collapse;background:var(--bg-primary);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);animation:fadeIn .3s ease}.transaction-table thead{background:var(--bg-tertiary)}.transaction-table th{padding:16px;text-align:left;font-weight:600;color:var(--text-primary);font-size:13px;text-transform:uppercase;letter-spacing:.5px}.transaction-table td{padding:14px 16px;border-top:1px solid var(--border);color:var(--text-primary);transition:background-color .2s ease}.transaction-table tbody tr{transition:all .2s ease}.transaction-table tbody tr:hover{background-color:var(--bg-secondary)}.transaction-table tbody tr:hover td{color:var(--text-primary)}.badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:600;transition:all .3s ease}.badge.income{background:#10b98126;color:var(--income)}.badge.expense{background:#ef444426;color:var(--expense)}.badge.category{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.badge:hover{transform:scale(1.05);box-shadow:0 2px 8px #6366f133}.modal{animation:modalSlideIn .3s cubic-bezier(.34,1.56,.64,1)}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:backdropFadeIn .3s ease}@keyframes backdropFadeIn{0%{background-color:#0000}to{background-color:#00000080}}.form-input:focus,.form-select:focus,input:focus,select:focus,textarea:focus{box-shadow:0 0 0 3px #6366f11a;border-color:var(--primary)}.page-wrapper{animation:pageTransition .3s ease}@keyframes pageTransition{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.card{animation:slideInUp .3s ease}.card:nth-child(2){animation-delay:.1s}.card:nth-child(3){animation-delay:.2s}.card:nth-child(4){animation-delay:.3s}.card:nth-child(5){animation-delay:.4s}.loading{opacity:.6;pointer-events:none}.loader{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.empty-state{text-align:center;padding:3rem;color:var(--text-muted)}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-state-text{font-size:1rem;margin-bottom:.5rem}.empty-state-subtext{font-size:.9rem;color:var(--text-muted)}*{transition-property:background-color,border-color,color,box-shadow;transition-duration:.2s;transition-timing-function:ease}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}.chart-container{padding:20px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);animation:slideInUp .4s ease}.tooltip{position:relative;background:var(--text-primary);color:var(--bg-primary);padding:8px 12px;border-radius:var(--radius-sm);font-size:12px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .2s ease;z-index:1000}[data-tooltip]:hover:after{opacity:1}.toast{position:fixed;bottom:20px;right:20px;padding:16px 20px;background:var(--bg-primary);border:2px solid var(--border);border-left:4px solid var(--success);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:slideInUp .3s ease;z-index:2000}.toast.error{border-left-color:var(--danger)}.toast.warning{border-left-color:var(--warning)}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{inset-inline:0;margin:0 auto}.hero .base{width:170px;position:relative;z-index:0}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;top:34px;height:28px;transform:perspective(2000px) rotate(300deg) rotateX(44deg) rotateY(39deg) scale(1.4)}.hero .vite{z-index:0;top:107px;height:26px;width:auto;transform:perspective(2000px) rotate(300deg) rotateX(40deg) rotateY(39deg) scale(.8)}#center{display:flex;flex-direction:column;gap:25px;place-content:center;place-items:center;flex-grow:1}@media (max-width: 1024px){#center{padding:32px 20px 24px;gap:18px}}#next-steps{display:flex;border-top:1px solid var(--border);text-align:left}#next-steps>div{flex:1 1 0;padding:32px}@media (max-width: 1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{margin-bottom:16px;width:22px;height:22px}@media (max-width: 1024px){#next-steps{flex-direction:column;text-align:center}}#docs{border-right:1px solid var(--border)}@media (max-width: 1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{list-style:none;padding:0;display:flex;gap:8px;margin:32px 0 0}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);font-size:16px;border-radius:6px;background:var(--social-bg);display:flex;padding:6px 12px;align-items:center;gap:8px;text-decoration:none;transition:box-shadow .3s}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{height:18px;width:18px}@media (max-width: 1024px){#next-steps ul{margin-top:20px;flex-wrap:wrap;justify-content:center}#next-steps ul li{flex:1 1 calc(50% - 8px)}#next-steps ul a{width:100%;justify-content:center;box-sizing:border-box}}#spacer{height:88px;border-top:1px solid var(--border)}@media (max-width: 1024px){#spacer{height:48px}}.ticks{position:relative;width:100%}.ticks:before,.ticks:after{content:"";position:absolute;top:-4.5px;border:5px solid transparent}.ticks:before{left:0;border-left-color:var(--border)}.ticks:after{right:0;border-right-color:var(--border)}
