.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-light);height:100vh;transition:width var(--transition-base);z-index:100;flex-direction:column;display:flex;position:fixed;top:0;left:0}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-header{padding:var(--space-4);border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;min-height:56px;display:flex}.sidebar.collapsed .sidebar-header{padding:var(--space-2);border-bottom:none;justify-content:center;min-height:auto}.sidebar-logo{font-size:var(--text-lg);background:linear-gradient(135deg, var(--accent), var(--accent-hover));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700}.sidebar-toggle{color:var(--text-muted);font-size:var(--text-sm);padding:var(--space-1);border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none}.sidebar-toggle:hover{background:var(--bg-elevated);color:var(--text-primary)}.sidebar-nav{padding:var(--space-3);gap:var(--space-1);flex-direction:column;flex:1;display:flex}.sidebar.collapsed .sidebar-nav{padding-top:var(--space-1)}.sidebar-link{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--text-sm);transition:all var(--transition-fast);font-weight:500;text-decoration:none;display:flex}.sidebar-link:hover{background:var(--bg-elevated);color:var(--text-primary)}.sidebar-link.active{background:var(--accent-muted);color:var(--accent)}.sidebar-icon{text-align:center;flex-shrink:0;width:24px;font-size:1.125rem}.sidebar-label{white-space:nowrap;overflow:hidden}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--border-light)}.sidebar-version{font-size:var(--text-xs);color:var(--text-muted)}.mobile-bottom-nav,.mobile-overlay{display:none}@media (width<=768px){.sidebar{display:none}.mobile-bottom-nav{height:64px;padding-bottom:env(safe-area-inset-bottom,0);background:var(--bg-secondary);border-top:1px solid var(--border-light);z-index:200;justify-content:space-around;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0}.mobile-nav-item{color:var(--text-muted);font-size:10px;font-weight:500;font-family:var(--font-sans);padding:var(--space-1) 0;transition:color var(--transition-fast);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;min-width:0;text-decoration:none;display:flex}.mobile-nav-item:hover,.mobile-nav-item:active{color:var(--text-primary)}.mobile-nav-item.active{color:var(--accent)}.mobile-nav-item .icon{width:22px;height:22px}.mobile-nav-label{white-space:nowrap;text-overflow:ellipsis;max-width:100%;overflow:hidden}.mobile-overlay{z-index:300;pointer-events:none;opacity:0;transition:opacity var(--transition-base);display:block;position:fixed;inset:0}.mobile-overlay.open{pointer-events:auto;opacity:1}.mobile-overlay-backdrop{background:#00000080;position:absolute;inset:0}.mobile-overlay-panel{background:var(--bg-secondary);padding:var(--space-4);padding-bottom:calc(var(--space-4) + env(safe-area-inset-bottom,0) + 72px);transition:transform var(--transition-base);border-top-left-radius:16px;border-top-right-radius:16px;max-height:60vh;position:absolute;bottom:0;left:0;right:0;overflow-y:auto;transform:translateY(100%)}.mobile-overlay.open .mobile-overlay-panel{transform:translateY(0)}.mobile-overlay-header{margin-bottom:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;display:flex}.mobile-overlay-title{font-size:var(--text-base);background:linear-gradient(135deg, var(--accent), var(--accent-hover));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700}.mobile-overlay-close{color:var(--text-muted);padding:var(--space-2);border-radius:var(--radius-sm);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none}.mobile-overlay-nav{gap:var(--space-1);flex-direction:column;display:flex}.mobile-overlay-link{align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius);color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;font-family:var(--font-sans);transition:all var(--transition-fast);cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent;background:0 0;border:none;width:100%;text-decoration:none;display:flex}.mobile-overlay-link:hover,.mobile-overlay-link:active{background:var(--bg-elevated);color:var(--text-primary)}.mobile-overlay-link.active{background:var(--accent-muted);color:var(--accent)}.mobile-overlay-link .icon{flex-shrink:0;width:20px;height:20px}.mobile-overlay-version{text-align:center;margin-top:var(--space-4);padding-top:var(--space-3);border-top:1px solid var(--border-light);font-size:var(--text-xs);color:var(--text-muted)}}.app-shell{min-height:100vh;display:flex}.app-content{margin-left:var(--sidebar-width);padding:var(--space-6);max-width:calc(var(--content-max-width) + var(--sidebar-width));transition:margin-left var(--transition-base);flex:1}@media (width<=768px){.app-content{padding:var(--space-3);padding-bottom:calc(72px + env(safe-area-inset-bottom,0) + var(--space-3));max-width:100%;margin-left:0}}@font-face{font-family:Inter;src:url(/fonts/inter-variable.woff2)format("woff2");font-weight:100 900;font-display:swap;font-style:normal}@font-face{font-family:JetBrains Mono;src:url(/fonts/jetbrains-mono-variable.woff2)format("woff2");font-weight:100 800;font-display:swap;font-style:normal}:root{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-elevated:#334155;--border:#475569;--border-light:#334155;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--accent:#6366f1;--accent-hover:#818cf8;--accent-muted:#6366f133;--positive:#10b981;--negative:#f87171;--danger:#f87171;--warning:#fbbf24;--info:#38bdf8;--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.5rem;--text-2xl:2rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-7:1.75rem;--space-8:2rem;--sidebar-width:240px;--sidebar-collapsed:64px;--content-max-width:1200px;--radius:8px;--radius-sm:4px;--transition-fast:.15s ease;--transition-base:.25s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-primary);background:var(--bg-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}code,pre{font-family:var(--font-mono)}button{cursor:pointer;font-family:inherit}table{border-collapse:collapse;width:100%}.icon{flex-shrink:0;width:20px;height:20px}.icon-sm{flex-shrink:0;width:18px;height:18px}.icon-lg{flex-shrink:0;width:48px;height:48px}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.skip-to-content{left:-9999px;top:var(--space-2);z-index:999;padding:var(--space-2) var(--space-4);background:var(--accent);color:var(--bg-primary);border-radius:var(--radius-sm);font-weight:600;text-decoration:none;position:absolute}.skip-to-content:focus{left:var(--space-4)}@media (width<=768px){html{font-size:15px}::-webkit-scrollbar{width:4px}}.card{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius);padding:var(--space-4)}.card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--text-lg);color:var(--text-primary);font-weight:600}.btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);font-size:var(--text-sm);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-weight:500;display:inline-flex}.btn:hover{background:var(--bg-primary);color:var(--text-primary);border-color:var(--border-light)}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg-elevated);color:var(--text-primary)}.badge{align-items:center;gap:var(--space-1);padding:2px var(--space-2);font-size:var(--text-xs);white-space:nowrap;border-radius:9999px;font-weight:500;display:inline-flex}.badge-success{color:var(--positive);background:#10b98126}.badge-warning{color:var(--warning);background:#fbbf2426}.badge-info{color:var(--info);background:#38bdf826}.table-scroll{-webkit-overflow-scrolling:touch;margin:0 calc(-1 * var(--space-4));padding:0 var(--space-4);overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th{text-align:left;padding:var(--space-3) var(--space-4);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);font-weight:600}.table td{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text-secondary);border-bottom:1px solid var(--border-light)}.table tr:hover td{background:var(--bg-elevated);color:var(--text-primary)}.table tr{cursor:pointer;transition:background var(--transition-fast)}.amount{font-family:var(--font-mono);font-size:var(--text-sm);text-align:right;white-space:nowrap;font-weight:500}.amount-positive{color:var(--positive)}.amount-negative{color:var(--negative)}.filter-tabs{gap:var(--space-2);margin-bottom:var(--space-6);display:flex}.filter-tab{padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);font-size:var(--text-sm);border:1px solid var(--border-light);color:var(--text-secondary);transition:all var(--transition-fast);background:0 0;font-weight:500}.filter-tab:hover{border-color:var(--border);color:var(--text-primary)}.filter-tab.active{background:var(--accent-muted);border-color:var(--accent);color:var(--accent)}.dropzone{border:2px dashed var(--border);border-radius:var(--radius);padding:var(--space-8);text-align:center;transition:all var(--transition-base);cursor:pointer}.dropzone:hover,.dropzone.dragging{border-color:var(--accent);background:var(--accent-muted)}.dropzone-icon{margin-bottom:var(--space-4);color:var(--text-muted);font-size:2rem}.dropzone-text{color:var(--text-secondary);font-size:var(--text-sm)}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:24px;height:24px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{padding:var(--space-8);justify-content:center;align-items:center;gap:var(--space-3);color:var(--text-secondary);display:flex}.empty-state{text-align:center;padding:var(--space-8);color:var(--text-muted)}.empty-state-icon{margin-bottom:var(--space-4);font-size:3rem}.empty-state-title{font-size:var(--text-lg);color:var(--text-secondary);margin-bottom:var(--space-2);font-weight:600}.input,input[type=text],input[type=number],select{font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);transition:border-color var(--transition-fast);outline:none}.input:focus,input[type=text]:focus,input[type=number]:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-muted)}select{cursor:pointer;appearance:none;padding-right:var(--space-6);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394a3b8' d='M2.5 4.5L6 8l3.5-3.5'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat}.btn:disabled{opacity:.5;cursor:not-allowed}.page-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.page-header-controls{align-items:center;gap:var(--space-4);display:flex}.page-title{font-size:var(--text-xl);font-weight:700}.page-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-1)}.period-label{text-align:center;text-transform:capitalize;min-width:160px;font-weight:600}.stat-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2)}.stat-value{font-size:var(--text-lg);font-weight:700}.stat-value-xl{font-size:var(--text-2xl);font-weight:700;font-family:var(--font-mono)}.truncate{text-overflow:ellipsis;white-space:nowrap;max-width:250px;overflow:hidden}.progress-bar{background:var(--bg-elevated);width:100%;height:8px;margin-bottom:var(--space-2);border-radius:4px;overflow:hidden}.progress-fill{background:var(--accent);border-radius:4px;height:100%;transition:width .2s}.account-code{font-family:var(--font-mono);font-size:var(--text-xs)}.account-name{font-size:var(--text-xs);color:var(--text-muted)}.stat-grid-3{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:repeat(3,1fr);display:grid}.stat-grid-4{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:repeat(4,1fr);display:grid}.detail-grid{gap:var(--space-3);grid-template-columns:1fr 1fr;display:grid}.responsive-grid-2{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.responsive-grid-3{gap:var(--space-3);grid-template-columns:repeat(3,1fr);display:grid}.text-muted{color:var(--text-muted)}.text-sm{font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}.text-bold{font-weight:600}@media (width<=768px){.card{padding:var(--space-3)}.card-header{gap:var(--space-2);flex-wrap:wrap}.page-header{flex-direction:column;align-items:flex-start}.page-header-controls{gap:var(--space-2);flex-wrap:wrap;width:100%}.page-title{font-size:var(--text-lg)}.stat-grid-3{gap:var(--space-3);grid-template-columns:1fr}.stat-grid-4{gap:var(--space-3);grid-template-columns:repeat(2,1fr)}.detail-grid,.responsive-grid-2,.responsive-grid-3{grid-template-columns:1fr}.filter-tabs{gap:var(--space-1);margin-bottom:var(--space-4);flex-wrap:wrap}.filter-tab{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.table-scroll{margin:0 calc(-1 * var(--space-3));padding:0 var(--space-3)}.table th,.table td{padding:var(--space-2) var(--space-3);white-space:nowrap}.truncate{max-width:120px}.btn{min-height:40px;padding:var(--space-2) var(--space-3)}.period-label{min-width:120px;font-size:var(--text-sm)}.dropzone{padding:var(--space-4)}.stat-value-xl{font-size:var(--text-xl)}.categorize-line{gap:var(--space-2)!important;grid-template-columns:1fr!important}}
