:root{--bg: #f4f6fa;--bg-subtle: #ebeef5;--panel: #ffffff;--text: #1a1d26;--text-secondary: #555d6e;--muted: #8690a2;--primary: #4f46e5;--primary-hover: #4338ca;--primary-soft: rgba(79, 70, 229, .07);--primary-glow: rgba(79, 70, 229, .15);--success: #10b981;--success-soft: rgba(16, 185, 129, .1);--danger: #ef4444;--danger-soft: rgba(239, 68, 68, .08);--warning: #f59e0b;--warning-soft: rgba(245, 158, 11, .1);--info: #6366f1;--info-soft: rgba(99, 102, 241, .08);--border: #e2e5eb;--border-light: #eef0f4;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow: 0 2px 8px rgba(0, 0, 0, .05), 0 1px 2px rgba(0, 0, 0, .03);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .12);--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--sidebar-bg: #ffffff;--sidebar-text: #6b7280;--sidebar-active: var(--primary);--sidebar-hover: var(--bg);--sidebar-active-bg: var(--primary-soft);--transition: .2s cubic-bezier(.4, 0, .2, 1);font-family:Inter,system-ui,-apple-system,sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0}body{margin:0;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{text-decoration:none;color:inherit}input,select,button,textarea{font:inherit}button{cursor:pointer;border:none}input:not([class*=ant-]),select:not([class*=ant-]){width:100%;padding:10px 14px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--panel);color:var(--text);transition:border-color var(--transition),box-shadow var(--transition);outline:none}input:not([class*=ant-]):focus,select:not([class*=ant-]):focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.auth-page{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr;background:linear-gradient(135deg,#1e1b4b,#312e81,#4f46e5)}.hero-panel{padding:64px;display:flex;align-items:center;color:#fff}.hero-panel h1{font-size:3rem;font-weight:800;line-height:1.1;margin:16px 0;letter-spacing:-.02em}.hero-panel .muted{color:#fff9}.tag,.badge{display:inline-block;padding:4px 10px;border-radius:999px;background:#4f46e514;color:var(--primary);font-weight:600;font-size:.78rem}.large{font-size:1.1rem}.auth-page .tag,.auth-page .badge{background:#ffffff26;color:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);padding:6px 14px;font-size:.85rem}.auth-card{background:var(--panel);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);margin:auto 48px auto 0;padding:36px;max-width:440px;border:none}.auth-card h2{margin-bottom:24px;font-weight:700}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border-radius:var(--radius-sm);font-weight:500;font-size:.9rem;border:1.5px solid var(--border);background:var(--panel);color:var(--text);transition:all var(--transition);white-space:nowrap}.btn:hover{background:var(--bg);border-color:#d1d5db}.btn:active{transform:scale(.97)}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover);box-shadow:0 4px 14px var(--primary-glow)}.btn-secondary{background:var(--bg);color:var(--text-secondary);border-color:var(--border)}.btn-secondary:hover{background:var(--bg-subtle)}.btn-danger{background:var(--danger-soft);color:var(--danger);border-color:transparent}.btn-danger:hover{background:var(--danger);color:#fff}.btn-edit{background:var(--primary-soft);color:var(--primary);border-color:transparent}.btn-edit:hover{background:var(--primary);color:#fff}.btn-transfer{background:var(--info-soft);color:var(--info);border-color:transparent;font-weight:600}.btn-transfer:hover{background:var(--info);color:#fff;box-shadow:0 4px 14px #6366f140}.btn-transfer:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn-adjust{background:var(--warning-soft);color:#b45309;border-color:transparent}.btn-adjust:hover{background:var(--warning);color:#fff;box-shadow:0 4px 14px #f59e0b40}.btn-link{background:transparent;color:var(--primary);border-color:transparent;padding:10px 4px}.btn-link:hover{color:var(--primary-hover);background:transparent}.btn-change-pw{background:var(--primary-soft);color:var(--primary);border-color:transparent}.btn-change-pw:hover{background:#4f46e524;color:var(--primary-hover)}.full-width{width:100%}.small{padding:6px 12px;font-size:.82rem}.field{display:grid;gap:6px;margin-bottom:16px}.field label{font-size:.85rem;font-weight:600;color:var(--text-secondary)}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.field-full{grid-column:1 / -1}.error-text{color:var(--danger);font-size:.85rem}.success-text{color:var(--success);font-size:.85rem}.password-wrapper{position:relative}.password-wrapper input{width:100%;padding-right:42px}.password-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--muted);display:flex;align-items:center;padding:4px}.app-shell{min-height:100vh;display:grid;grid-template-columns:250px 1fr}.sidebar{background:var(--sidebar-bg);padding:24px 14px;display:flex;flex-direction:column;gap:24px;border-right:1px solid var(--border);position:sticky;top:0;height:100vh;overflow-y:auto}.brand{font-size:1.3rem;font-weight:800;color:var(--primary);letter-spacing:-.02em;padding:0 10px}.sidebar nav{display:grid;gap:2px}.sidebar nav a{padding:10px 14px;border-radius:var(--radius-sm);color:var(--sidebar-text);display:flex;align-items:center;gap:12px;font-size:.9rem;font-weight:500;transition:all var(--transition);position:relative}.sidebar nav a:hover{background:var(--sidebar-hover);color:var(--text)}.sidebar nav a.active{background:var(--sidebar-active-bg);color:var(--sidebar-active);font-weight:600}.sidebar nav a.active:before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;border-radius:0 3px 3px 0;background:var(--primary)}.sidebar-footer{margin-top:auto;display:grid;gap:8px}.user-info{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--radius-sm);background:var(--bg);margin-bottom:4px}.avatar{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--info));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.95rem;flex-shrink:0}.user-info strong{display:block;line-height:1.3;font-size:.88rem;color:var(--text)}.user-handle{font-size:.75rem;color:var(--muted)}.content{padding:32px;background:var(--bg);min-height:100vh}.page{display:grid;gap:24px}.page-header{display:flex;justify-content:space-between;align-items:center;gap:16px}.page-header h1{margin:0 0 4px;font-size:1.5rem;font-weight:700;letter-spacing:-.01em}.muted{color:var(--muted);font-size:.9rem}.page-header-actions{display:flex;gap:10px;align-items:center}.card{background:var(--panel);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow);transition:box-shadow var(--transition),border-color var(--transition)}.stats-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px}.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}.stat-card{display:flex;justify-content:space-between;align-items:start;padding:16px 20px}.stat-card h3{margin:4px 0 0;font-size:1.4rem;font-weight:700;letter-spacing:-.02em}.stat-card .badge{font-size:.72rem;padding:4px 8px}.stat-card .rate-dot{display:inline-block;vertical-align:middle;margin-right:4px}.chart-card{padding:24px}.chart-card .recharts-responsive-container{margin:0 -24px -24px;width:calc(100% + 48px)!important}.chart-tooltip{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;font-size:.85rem;color:var(--text);line-height:1.7;box-shadow:var(--shadow-md)}.chart-tooltip-label{font-weight:700;margin-bottom:4px;font-size:.9rem}.table-card,.budget-card,.inline-form,.form-grid,.form-compact{padding:24px}.card-head,.budget-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.actions{display:flex;gap:10px;align-items:center}.align-end{align-self:end}.inline-form{display:grid;grid-template-columns:1fr 1fr auto;gap:16px;align-items:end}.inline-form .field{margin-bottom:0}.category-form{display:grid;grid-template-columns:auto auto 1fr auto;gap:16px;align-items:end;padding:24px}.category-form .field{margin-bottom:0}.category-tree{margin-top:12px;overflow:hidden}.tree-group{border-bottom:1px solid var(--border-light)}.tree-group:last-child{border-bottom:none}.tree-parent,.tree-child{display:flex;justify-content:space-between;align-items:center;padding:10px 0;min-width:0}.tree-parent{font-weight:600}.tree-child{padding-left:28px;color:var(--text-secondary)}.tree-child:before{content:"└ ";color:var(--border);margin-right:4px}.tree-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse}th{text-align:left;padding:12px 10px;font-size:.85rem;font-weight:700;color:var(--text);border-bottom:2px solid var(--border)}td{text-align:left;padding:13px 10px;border-bottom:1px solid var(--border-light);font-size:.9rem}tbody tr{transition:background var(--transition)}tbody tr:hover{background:var(--primary-soft)}tbody tr:last-child td{border-bottom:none}.pill{display:inline-flex;align-items:center;padding:3px 10px;border-radius:6px;font-size:.78rem;font-weight:600;letter-spacing:.01em}.pill.income{background:var(--success-soft);color:#059669}.pill.expense{background:var(--danger-soft);color:#dc2626}.pill.adjustment{background:var(--warning-soft);color:#b45309}.pill.transfer{background:var(--info-soft);color:#4f46e5}.table-actions{display:flex;gap:6px;flex-shrink:0}.table-info{padding-bottom:12px;font-size:.88rem;color:var(--text-secondary)}.table-info strong{color:var(--primary)}.empty-state{text-align:center;color:var(--muted);padding:48px 20px;font-size:.95rem}.progress{height:6px;border-radius:999px;background:var(--bg-subtle);overflow:hidden;margin:12px 0}.progress-bar{height:100%;background:linear-gradient(90deg,var(--primary),var(--info));border-radius:999px;transition:width .6s cubic-bezier(.4,0,.2,1)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;z-index:100;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--panel);border-radius:var(--radius-lg);box-shadow:0 24px 64px #0000002e;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-content-wide{max-width:720px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 0}.modal-header h2{margin:0;font-size:1.15rem;font-weight:700}.modal-header .btn{font-size:1.3rem;padding:4px 10px;border:none;color:var(--muted)}.modal-header .btn:hover{color:var(--text);background:transparent}.modal-body{padding:20px 24px 24px}.modal-body .form-grid{gap:14px}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding-top:8px}.modal-body .ant-picker,.modal-body .ant-input-number{width:100%;height:42px!important;border-radius:var(--radius-sm)!important}.modal-body .ant-input-number-input{height:40px!important;padding:0 14px!important}.filter-bar{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-end;padding:16px 20px}.filter-group{display:flex;flex-direction:column;gap:5px}.filter-group label{font-size:.75rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.filter-bar .ant-picker,.filter-bar .ant-select,.filter-bar .ant-input-affix-wrapper,.filter-bar .ant-input{height:38px!important;border-radius:var(--radius-sm)!important;font-size:.88rem}.filter-bar .ant-select .ant-select-selector{height:38px!important;border-radius:var(--radius-sm)!important;display:flex;align-items:center}.filter-bar .ant-input-affix-wrapper{display:flex;align-items:center}.filter-bar .ant-input-affix-wrapper .ant-input{height:auto!important;border-radius:0!important;border:none!important;box-shadow:none!important}.filter-row{display:flex;gap:14px;flex:1}.filter-grow{flex:1}.filter-bar .btn-search{height:38px;padding:0 20px;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;align-self:flex-end}.ant-picker-dropdown .ant-picker-cell{padding:6px 0!important}.ant-picker-dropdown .ant-picker-cell-inner{display:inline-flex!important;align-items:center!important;justify-content:center!important;min-width:32px!important;min-height:32px!important;line-height:32px!important}.ant-picker-dropdown .ant-picker-content th{padding:8px 0!important}.ant-picker-dropdown .ant-picker-content td{text-align:center!important}.pagination{display:flex;gap:4px;justify-content:center;padding-top:16px}.pagination .btn{min-width:36px;padding:6px 10px;font-size:.85rem;border-radius:var(--radius-sm)}.pagination .btn:disabled{opacity:.35;cursor:default}.wallets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.wallet-card{padding:20px;display:flex;flex-direction:column;gap:12px;transition:all var(--transition);cursor:pointer}.wallet-card:hover{border-color:var(--primary);box-shadow:0 4px 20px var(--primary-glow);transform:translateY(-2px)}.wallet-card-header{display:flex;justify-content:space-between;align-items:center}.wallet-card-header h3{margin:0;font-size:1.05rem;font-weight:600}.wallet-balance{font-size:1.45rem;font-weight:700;letter-spacing:-.02em}.rate-banner{padding:12px 20px;font-size:.88rem;display:flex;align-items:center;gap:8px;flex-wrap:wrap;color:var(--text-secondary)}.rate-dot{width:7px;height:7px;border-radius:50%;background:var(--success);animation:pulse-dot 2s infinite;flex-shrink:0}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.center-screen{min-height:100vh;display:grid;place-items:center;color:var(--muted)}.spinner-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:80px 20px}.spinner{width:28px;height:28px;border:2.5px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .65s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.mobile-header{display:none}.hamburger{background:none;border:none;padding:8px;display:flex;flex-direction:column;gap:5px;cursor:pointer}.hamburger span{display:block;width:20px;height:2px;background:var(--text);border-radius:2px;transition:all var(--transition)}.sidebar-overlay{display:none}@media (max-width: 980px){.auth-page{grid-template-columns:1fr}.auth-card{margin:0 20px 20px;max-width:unset}.hero-panel{padding:32px 20px}.stats-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.grid-2,.grid-3{grid-template-columns:1fr}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.inline-form,.category-form{grid-template-columns:1fr}.content{padding:24px}.page-header{flex-direction:column;align-items:stretch}}@media (max-width: 768px){.app-shell{grid-template-columns:1fr;grid-template-rows:auto 1fr;max-width:100vw;overflow-x:hidden}.mobile-header{display:flex;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border);background:var(--panel);position:sticky;top:0;z-index:50;grid-row:1;align-self:start}.content{grid-row:2}.mobile-header .brand{font-size:1.15rem;color:var(--primary)}.sidebar{position:fixed;top:0;left:0;bottom:0;width:260px;z-index:200;transform:translate(-100%);transition:transform .25s ease}.sidebar.sidebar-open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:150}.content{padding:12px}.page{gap:10px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}.stat-card{padding:10px 12px;flex-direction:column;gap:2px}.stat-card h3{font-size:1.05rem;margin-top:2px}.stat-card .muted{font-size:.78rem}.stat-card .badge{font-size:.62rem;padding:2px 6px;align-self:flex-start}.rate-card{grid-column:1 / -1;flex-direction:row;align-items:center;padding:6px 12px;gap:8px;border-radius:var(--radius-sm)}.rate-card>div{display:flex;align-items:center;gap:8px}.rate-card p.muted{font-size:.75rem;margin:0}.rate-card h3{font-size:.85rem;margin:0;font-weight:600}.form-grid,.inline-form,.category-form{grid-template-columns:1fr}.filter-bar{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:8px 10px}.filter-bar .btn-search{grid-column:1 / -1}.filter-group{gap:2px}.filter-group label{font-size:.7rem}.filter-bar .ant-picker,.filter-bar .ant-select,.filter-bar .ant-input-affix-wrapper,.filter-bar .ant-input{width:100%!important;min-width:0!important;height:32px!important;font-size:.82rem}.filter-bar .ant-select .ant-select-selector{height:32px!important}.filter-bar .ant-select{width:100%!important}.filter-bar .btn-search{width:100%;height:32px;padding:0;font-size:.85rem}.filter-row{flex-direction:column;gap:6px}.filter-bar .ant-picker-range{height:auto!important;min-height:32px;padding:4px 8px!important}.filter-bar .ant-picker-range .ant-picker-input{width:100%}.filter-bar .ant-picker-range .ant-picker-input>input{font-size:.82rem!important;text-align:center}.ant-picker-dropdown .ant-picker-panels{flex-direction:column!important}.page{max-width:100%;overflow:hidden}.table-card{padding:12px;overflow:hidden}.table-scroll{margin:0 -12px;padding:0 12px;overflow-x:auto}.table-scroll table{min-width:600px}th,td{padding:10px 8px;font-size:.85rem;white-space:nowrap}.modal-content{max-width:calc(100vw - 20px);max-height:calc(100vh - 20px);border-radius:var(--radius)}.modal-header{padding:10px 10px 0}.modal-header h2{font-size:1rem}.modal-body{padding:8px 10px 10px}.modal-body .form-grid{grid-template-columns:1fr;gap:4px;padding:0 24px 24px}.modal-body .field{margin-bottom:4px;gap:2px}.modal-body .field label{font-size:.78rem}.modal-body input:not([class*=ant-]),.modal-body select:not([class*=ant-]){padding:7px 10px;font-size:.88rem}.modal-body .ant-picker,.modal-body .ant-input-number{height:34px!important}.modal-body .ant-input-number-input{height:32px!important;padding:0 10px!important}.modal-body .ant-select .ant-select-selector{height:34px!important}.modal-footer{padding-top:6px;gap:8px}.modal-footer .btn{padding:7px 14px;font-size:.85rem}.chart-card{padding:12px}.chart-card .recharts-responsive-container{margin:0 -12px -12px;width:calc(100% + 24px)!important}.page-header{flex-direction:column;align-items:stretch;gap:10px}.page-header h1{font-size:1.25rem}.page-header-actions,.pagination{flex-wrap:wrap}.tree-child{padding-left:16px}.table-actions{gap:4px}.table-actions .btn.small{padding:5px 8px;font-size:.78rem}.wallet-card{padding:14px;gap:8px}.wallet-card:hover{transform:none}.wallet-balance{font-size:1.2rem}}@media (max-width: 480px){.content{padding:10px}.card{border-radius:var(--radius)}.modal-content{border-radius:var(--radius-sm)}.stat-card h3{font-size:1rem}.page-header h1{font-size:1.1rem}.hero-panel h1{font-size:2rem}.hero-panel{padding:24px 16px}}
