*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #0FB0A3;--primary-dark: #0A8278;--primary-light: #E3F7F4;--success: #1F9D55;--danger: #D14343;--warning: #C58A1C;--gray-50: #FAFAF7;--gray-100: #F4F2EC;--gray-200: #E7E4D9;--gray-300: #D6D2C4;--gray-400: #9A988F;--gray-500: #6B6A63;--gray-700: #2E2E2E;--gray-900: #111418;--bg-body: #FFFFFF;--bg-card: #FAFAF7;--bg-modal: #FFFFFF;--text-main: #111418;--border: #E7E4D9;--table-hover: #F4F2EC;--input-bg: #FFFFFF;--input-border:#D6D2C4;--sidebar-bg: #FAFAF7;--sidebar-hover: #F0ECE2;--sidebar-active: #E3F7F4;--sidebar-fg: #111418;--sidebar-fg-muted:#6B6A63;--sidebar-label: #9A988F;--sidebar-accent: #0FB0A3;--sidebar-w: 208px;--radius: 4px;--font-sans: "Inter","Noto Sans TC",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-mono: "JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace}[data-theme=dark]{--primary: #2DE0D0;--primary-dark: #0FB0A3;--primary-light: rgba(45,224,208,.1);--success: #3BD67C;--danger: #F5605C;--warning: #F0B144;--gray-50: #12181D;--gray-100: #171E24;--gray-200: #222A31;--gray-300: #2B353E;--gray-400: #5C6670;--gray-500: #8A939C;--gray-700: #C5CBD1;--gray-900: #E8ECEF;--bg-body: #0B0F12;--bg-card: #12181D;--bg-modal: #171E24;--text-main: #E8ECEF;--border: #222A31;--table-hover:#171E24;--input-bg: #0B0F12;--input-border:#2B353E;--sidebar-bg: #12181D;--sidebar-hover: #171E24;--sidebar-active: rgba(45,224,208,.08);--sidebar-fg: #E8ECEF;--sidebar-fg-muted:#8A939C;--sidebar-label: #5C6670;--sidebar-accent: #2DE0D0;color-scheme:dark}body{font-family:var(--font-sans);color:var(--text-main);background:var(--bg-body);line-height:1.5;-webkit-font-smoothing:antialiased;transition:background-color .2s ease,color .2s ease}.tabular,.stat-card .value,table td:has(>.tabular),th.num,td.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}a{color:var(--primary-dark);text-decoration:none}a:hover{text-decoration:underline}[data-theme=dark] a{color:var(--primary)}button,.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-main);border-radius:var(--radius);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,opacity .15s}button:hover:not(:disabled){background:var(--gray-100)}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600}.btn-primary:hover:not(:disabled){background:var(--primary-dark);border-color:var(--primary-dark)}[data-theme=dark] .btn-primary{color:#0b0f12}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-ghost{background:transparent;border-color:transparent;color:var(--gray-700)}.btn-ghost:hover{background:var(--gray-100)}.btn-success{background:var(--success);color:#fff;border-color:var(--success)}input,select,textarea{width:100%;padding:8px 12px;border:1px solid var(--input-border);border-radius:var(--radius);font-size:13.5px;outline:none;background:var(--input-bg);color:var(--text-main);font-family:var(--font-sans);transition:border-color .15s,box-shadow .15s,background-color .2s}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}input::placeholder,textarea::placeholder{color:var(--gray-400)}.card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);padding:18px 20px;box-shadow:none;transition:background-color .2s,border-color .2s}table{width:100%;border-collapse:collapse;font-size:13px}th,td{padding:8px 12px;text-align:left;border-bottom:1px solid var(--border)}th{font-weight:700;color:var(--gray-500);font-size:10.5px;text-transform:uppercase;letter-spacing:.8px;background:var(--gray-50);font-family:var(--font-mono);padding:7px 12px}tr:hover td{background:var(--table-hover)}th.num,td.num{text-align:right;font-family:var(--font-mono)}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);border-right:1px solid var(--border);position:fixed;top:0;left:0;bottom:0;z-index:100;display:flex;flex-direction:column}.main{margin-left:var(--sidebar-w);flex:1;padding:20px 28px;min-width:0}.sidebar-header{flex-shrink:0;padding:16px 14px 12px;border-bottom:1px solid var(--border)}.sidebar .logo{display:flex;align-items:center;gap:8px;font-size:14.5px;font-weight:700;color:var(--sidebar-fg);letter-spacing:.2px}.sidebar .logo:before{content:"K";display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:var(--text-main);color:var(--bg-body);font-weight:800;font-size:13px;letter-spacing:-.06em}.sidebar .logo .dot{color:var(--primary)}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:6px 0;scrollbar-width:thin;scrollbar-color:var(--gray-300) transparent}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:4px}.sidebar-nav a{display:flex;align-items:center;gap:9px;padding:6px 14px;color:var(--sidebar-fg);font-size:12.5px;text-decoration:none;border-left:2px solid transparent;transition:background .15s,color .15s}.sidebar-nav a:hover{background:var(--sidebar-hover);text-decoration:none}.sidebar-nav a.active{color:var(--primary-dark);background:var(--sidebar-active);border-left-color:var(--sidebar-accent);font-weight:600}[data-theme=dark] .sidebar-nav a.active{color:var(--primary)}.nav-group{margin-top:8px}.nav-group:first-child{margin-top:2px}.nav-group-label{padding:6px 14px 3px;font-family:var(--font-mono);font-size:9.5px;font-weight:600;letter-spacing:1.5px;color:var(--sidebar-label);text-transform:uppercase}.sidebar-footer{flex-shrink:0;padding:10px 14px;border-top:1px solid var(--border);font-family:var(--font-mono);font-size:10px;color:var(--gray-500)}.mobile-menu-btn{display:none;position:fixed;top:10px;left:10px;z-index:200;width:40px;height:40px;border-radius:var(--radius);background:var(--bg-card);color:var(--text-main);border:1px solid var(--border);font-size:18px;cursor:pointer;justify-content:center;align-items:center;padding:0}.sidebar-overlay{display:none}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-header h1{font-size:20px;font-weight:600;letter-spacing:-.01em;display:flex;align-items:center;gap:10px}.page-header h1:before{content:attr(data-crumb);font-family:var(--font-mono);font-size:10px;font-weight:500;color:var(--gray-400);letter-spacing:1.5px;text-transform:uppercase}.grid-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;margin-bottom:16px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px}.stat-card .label{font-size:10px;color:var(--gray-500);letter-spacing:1.3px;font-family:var(--font-mono);font-weight:600;text-transform:uppercase;margin-bottom:4px}.stat-card .value{font-size:22px;font-weight:600;font-family:var(--font-mono);font-variant-numeric:tabular-nums;letter-spacing:-.01em}.stat-card .value.income{color:var(--success)}.stat-card .value.expense{color:var(--danger)}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:11px;font-weight:600;color:var(--gray-500);font-family:var(--font-mono);letter-spacing:.8px;text-transform:uppercase;margin-bottom:4px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0a0a73;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--bg-modal);color:var(--text-main);border:1px solid var(--border);border-radius:var(--radius);padding:22px;width:480px;max-width:90vw;max-height:90vh;overflow-y:auto}.modal h2{font-size:16px;margin-bottom:14px;font-weight:600}.toggle-group{display:flex;gap:0;border-radius:var(--radius);overflow:hidden;border:1px solid var(--input-border)}.toggle-group button{flex:1;padding:9px;border:none;border-radius:0;background:var(--bg-card);color:var(--text-main);font-weight:600;cursor:pointer;font-family:var(--font-mono);font-size:11px;letter-spacing:1px}.toggle-group button.active-income{background:#1f9d551a;color:var(--success)}.toggle-group button.active-expense{background:#d1434314;color:var(--danger)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:2px;font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.6px}.badge-success{background:#1f9d551a;color:var(--success)}.badge-danger{background:#d1434314;color:var(--danger)}.badge-warning{background:#c58a1c1f;color:var(--warning)}.badge-info{background:var(--primary-light);color:var(--primary-dark)}.badge-gray{background:var(--gray-100);color:var(--gray-500)}[data-theme=dark] .badge-info{color:var(--primary)}.toast{position:fixed;top:20px;right:20px;padding:10px 18px;border-radius:var(--radius);background:var(--primary);color:#fff;font-weight:500;z-index:2000;font-size:13px;border:1px solid var(--primary-dark);animation:slideIn .3s ease}[data-theme=dark] .toast{color:#0b0f12}@keyframes slideIn{0%{transform:translate(100%);opacity:0}}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:18px;font-family:var(--font-mono)}.tabs button{padding:9px 16px;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;font-weight:500;color:var(--gray-500);cursor:pointer;font-size:11px;letter-spacing:1px;text-transform:uppercase}.tabs button.active{color:var(--primary-dark);border-bottom-color:var(--primary);font-weight:700}[data-theme=dark] .tabs button.active{color:var(--primary)}.empty-state{text-align:center;padding:60px 20px;color:var(--gray-500)}.empty-state p{font-size:14px;margin-bottom:16px}.skeleton-pulse{animation:skeleton-pulse 1.4s ease-in-out infinite}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.5}}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:var(--border)}.recharts-text{fill:var(--gray-500);font-family:var(--font-mono);font-size:10px}.recharts-tooltip-wrapper .recharts-default-tooltip{background:var(--bg-modal)!important;border:1px solid var(--border)!important;border-radius:var(--radius)!important;color:var(--text-main)!important;font-family:var(--font-mono)!important;font-size:11px!important}@media (max-width: 768px){.mobile-menu-btn{display:flex}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:99;background:#0a0a0a73}.sidebar{transform:translate(-100%);transition:transform .25s ease;width:260px;z-index:150}.sidebar.sidebar-open{transform:translate(0)}.main{margin-left:0;padding:56px 12px 16px}.grid-stats{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}.stat-card{padding:10px 12px}.stat-card .label{font-size:9.5px}.stat-card .value{font-size:17px}.page-header{flex-wrap:wrap;gap:8px;margin-bottom:14px}.page-header h1{font-size:17px}.card{padding:12px}table{font-size:12.5px}th,td{padding:7px 6px}.modal{width:95vw;padding:16px;max-height:95vh}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.tabs button{white-space:nowrap;padding:9px 12px;font-size:10.5px}button,.btn{min-height:36px}.form-group{margin-bottom:12px}}@media (max-width: 480px){.grid-stats{grid-template-columns:1fr 1fr}.main{padding:52px 10px 16px}.page-header h1,.stat-card .value{font-size:16px}}
