*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #070710;--card-bg: rgba(255,255,255,.025);--card-border: rgba(255,255,255,.06);--text: #ffffff;--text-sub: rgba(255,255,255,.65);--text-muted: rgba(255,255,255,.35);--green: #4ade80;--red: #f87171;--blue: #60a5fa;--bar-fill: rgba(255,255,255,.75);--bar-track: rgba(255,255,255,.1);--radius: 10px;--radius-sm: 6px;--header-h: 64px;--nav-h: 48px}html{background:var(--bg);color:var(--text);font-family:Inter,system-ui,sans-serif;font-size:14px;-webkit-font-smoothing:antialiased;overflow-y:scroll;scrollbar-gutter:stable}body{background:var(--bg);min-height:100vh}button{cursor:pointer;font-family:inherit;background:none;border:none;color:inherit}input,select,textarea{font-family:inherit;color:var(--text);background:none;border:none;outline:none}input[type=number]{-moz-appearance:textfield}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}table{border-collapse:collapse;width:100%}.app{display:flex;flex-direction:column;min-height:100vh}.header{position:sticky;top:0;z-index:50;height:var(--header-h);display:flex;align-items:center;justify-content:space-between;padding:0 20px;background:#070710e6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--card-border)}.header-left{display:flex;flex-direction:column;gap:1px}.header-title{font-size:15px;font-weight:600;letter-spacing:-.02em}.header-month{font-size:11px;font-weight:300;color:var(--text-muted);letter-spacing:.01em}.header-right{display:flex;align-items:center;gap:6px}.icon-btn{display:flex;align-items:center;gap:5px;padding:6px 10px;border-radius:var(--radius-sm);font-size:12px;font-weight:500;color:var(--text-sub);border:1px solid transparent;transition:color .15s,background .15s,border-color .15s;white-space:nowrap}.icon-btn:hover{color:var(--text);background:#ffffff0f}.icon-btn.active{color:var(--text);background:#ffffff14;border-color:var(--card-border)}.icon-btn .icon{font-size:14px;line-height:1}@keyframes spin{to{transform:rotate(360deg)}}.spin{display:inline-block;animation:spin .8s linear infinite}.nav-wrapper{position:sticky;top:var(--header-h);z-index:40;background:#070710d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--card-border)}.nav-main{display:flex;justify-content:center;gap:4px;padding:8px 20px}.nav-btn{padding:6px 16px;border-radius:20px;font-size:13px;font-weight:500;color:var(--text-muted);transition:color .15s,background .15s}.nav-btn:hover{color:var(--text-sub)}.nav-btn.active{color:var(--text);background:#ffffff14}.nav-sub{display:flex;justify-content:center;gap:4px;padding:0 20px 8px}.sub-btn{padding:4px 14px;border-radius:16px;font-size:12px;font-weight:400;color:var(--text-muted);transition:color .15s,background .15s}.sub-btn:hover{color:var(--text-sub)}.sub-btn.active{color:var(--text);background:#ffffff12}.main-content{flex:1;max-width:760px;width:100%;margin:0 auto;padding:20px 16px 40px}.inline-panel{max-width:760px;width:100%;margin:0 auto;padding:16px 16px 0}.panel-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius);overflow:hidden;margin-bottom:4px}.panel-tabs{display:flex;gap:2px;padding:10px 14px 0;border-bottom:1px solid var(--card-border)}.panel-tab-btn{padding:7px 14px;border-radius:6px 6px 0 0;font-size:12px;font-weight:500;color:var(--text-muted);transition:color .15s,background .15s;border-bottom:2px solid transparent;margin-bottom:-1px}.panel-tab-btn:hover{color:var(--text-sub)}.panel-tab-btn.active{color:var(--text);border-bottom-color:#ffffff80}.panel-body{padding:16px;max-height:340px;overflow-y:auto}.section{margin-bottom:16px}.section-label{font-size:11px;font-weight:500;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px}.card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius);padding:16px}.card-sm{padding:12px 14px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.stat-card{padding:14px 16px}.stat-label{font-size:11px;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em;font-weight:500}.stat-value{font-size:20px;font-weight:600;letter-spacing:-.03em}.stat-value.green{color:var(--green)}.stat-value.red{color:var(--red)}.stat-value.blue{color:var(--blue)}.progress-wrap{width:100%;height:4px;background:var(--bar-track);border-radius:2px;overflow:hidden;margin-top:8px}.progress-fill{height:100%;background:var(--bar-fill);border-radius:2px;transition:width .4s ease}.chart-wrap{width:100%}.month-selected-label{text-align:center;font-size:11px;color:var(--text-muted);margin-top:6px;font-weight:500;letter-spacing:.03em}.pie-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.pie-card{padding:14px}.pie-label{font-size:11px;color:var(--text-muted);margin-bottom:12px;text-align:center;text-transform:uppercase;letter-spacing:.05em;font-weight:500}.pie-legend{margin-top:10px;display:flex;flex-direction:column;gap:5px}.pie-legend-row{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-sub)}.pie-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.pie-legend-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pie-legend-val{color:var(--text-muted);white-space:nowrap}.data-table{width:100%}.data-table th{font-size:11px;font-weight:500;color:var(--text-muted);text-align:left;padding:0 0 8px;border-bottom:1px solid rgba(255,255,255,.05);text-transform:uppercase;letter-spacing:.05em}.data-table td{padding:9px 0;border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.td-cat{font-size:13px;color:var(--text-sub);padding-right:8px}.td-amount{text-align:right;font-size:13px;font-weight:500;white-space:nowrap;padding-left:8px}.td-goal{width:120px;text-align:right}.cat-row:hover td{background:#ffffff05}.goal-bar-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:3px}.goal-amounts{font-size:11px;color:var(--text-muted)}.divider{height:1px;background:#ffffff0d;margin:8px 0}.empty{color:var(--text-muted);font-size:13px;padding:16px 0;text-align:center}.error-banner{background:#f871711a;border:1px solid rgba(248,113,113,.25);border-radius:var(--radius-sm);color:var(--red);font-size:12px;padding:10px 14px}.notif-list{display:flex;flex-direction:column;gap:6px}.notif-item{display:flex;align-items:center;justify-content:space-between;background:#f8717112;border:1px solid rgba(248,113,113,.2);border-radius:var(--radius-sm);padding:8px 12px;font-size:12px;gap:8px}.notif-name{color:var(--text-sub)}.notif-vals{display:flex;gap:6px;align-items:center;color:var(--text-muted);font-size:11px}.notif-over{color:var(--red);font-weight:600;font-size:12px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:#0d0d1a;border:1px solid var(--card-border);border-radius:var(--radius);width:100%;max-width:480px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--card-border);flex-shrink:0}.modal-title{font-size:15px;font-weight:600}.modal-total{font-size:12px;color:var(--text-muted);margin-top:2px}.modal-close{font-size:14px;color:var(--text-muted);padding:2px 4px;border-radius:4px;transition:color .15s}.modal-close:hover{color:var(--text)}.modal-body{overflow-y:auto;padding:4px 18px 16px;flex:1}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--bg)}.login-card{width:100%;max-width:340px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius);padding:32px 28px}.login-title{font-size:20px;font-weight:600;letter-spacing:-.02em;margin-bottom:4px}.login-sub{font-size:13px;color:var(--text-muted);margin-bottom:24px}.login-field{margin-bottom:14px}.login-label{display:block;font-size:11px;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.login-input{width:100%;background:#ffffff0a;border:1px solid var(--card-border);border-radius:var(--radius-sm);padding:9px 12px;font-size:14px;color:var(--text);transition:border-color .15s}.login-input:focus{border-color:#fff3}.login-btn{width:100%;margin-top:20px;padding:10px;background:#ffffff1a;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);font-size:14px;font-weight:500;color:var(--text);transition:background .15s}.login-btn:hover:not(:disabled){background:#ffffff24}.login-btn:disabled{opacity:.5;cursor:default}.settings-tabs{display:flex;gap:2px;margin-bottom:12px}.settings-tab-btn{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:500;color:var(--text-muted);transition:color .15s,background .15s}.settings-tab-btn:hover{color:var(--text-sub)}.settings-tab-btn.active{color:var(--text);background:#ffffff12}.intern-badge{font-size:10px;font-weight:500;padding:2px 7px;border-radius:10px;background:#ffffff0f;color:var(--text-muted)}.goal-input{width:80px;text-align:right;background:#ffffff0a;border:1px solid var(--card-border);border-radius:4px;padding:4px 8px;font-size:13px;color:var(--text);transition:border-color .15s}.goal-input:focus{border-color:#fff3}.form-row{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-end}.form-group{display:flex;flex-direction:column;gap:4px;flex:1;min-width:80px}.form-label{font-size:10px;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.04em}.form-input{background:#ffffff0a;border:1px solid var(--card-border);border-radius:4px;padding:6px 8px;font-size:13px;color:var(--text);width:100%;transition:border-color .15s}.form-input:focus{border-color:#fff3}.form-select{background:#ffffff0a;border:1px solid var(--card-border);border-radius:4px;padding:6px 8px;font-size:13px;color:var(--text);width:100%;transition:border-color .15s;cursor:pointer}.form-select option{background:#0d0d1a}.form-select:focus{border-color:#fff3}.btn{padding:7px 14px;border-radius:var(--radius-sm);font-size:12px;font-weight:500;background:#ffffff14;border:1px solid rgba(255,255,255,.1);color:var(--text);transition:background .15s}.btn:hover:not(:disabled){background:#ffffff1f}.btn:disabled{opacity:.5;cursor:default}.btn-sm{padding:5px 10px;font-size:11px}.btn-ghost{background:transparent;border-color:#ffffff0f;color:var(--text-muted)}.btn-ghost:hover:not(:disabled){background:#ffffff0d;color:var(--text-sub)}.btn-danger{background:#f871711a;border-color:#f8717133;color:var(--red)}.btn-danger:hover:not(:disabled){background:#f871712e}.rules-list{display:flex;flex-direction:column;gap:6px}.rule-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;background:#ffffff05;border:1px solid rgba(255,255,255,.04);border-radius:var(--radius-sm);padding:8px 12px}.rule-field{display:flex;align-items:center;gap:4px}.rule-key{font-size:10px;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.04em}.rule-val{font-size:12px;color:var(--text-sub)}.rule-actions{margin-left:auto;display:flex;gap:4px}.data-table-editable th{padding-right:8px}.data-table-editable td{padding:6px 0}.inline-input{background:#ffffff0a;border:1px solid transparent;border-radius:4px;padding:4px 7px;font-size:12px;color:var(--text);width:100%;transition:border-color .15s}.inline-input:focus,.inline-input:hover{border-color:var(--card-border)}.cat-select{background:#ffffff0a;border:1px solid transparent;border-radius:4px;padding:4px 7px;font-size:12px;color:var(--text);width:100%;cursor:pointer;transition:border-color .15s}.cat-select:hover,.cat-select:focus{border-color:var(--card-border)}.cat-select option{background:#0d0d1a}.upcoming-list{display:flex;flex-direction:column;gap:0}.upcoming-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.03);font-size:13px}.upcoming-row:last-child{border-bottom:none}.upcoming-name{color:var(--text-sub)}.upcoming-amount{color:var(--text-muted);font-weight:500}@media (max-width: 520px){.grid-3{grid-template-columns:repeat(3,1fr);gap:6px}.stat-value{font-size:15px}.stat-label{font-size:10px}.pie-grid{grid-template-columns:1fr}.header{padding:0 14px}.main-content{padding:14px 12px 32px}.inline-panel{padding:12px 12px 0}.td-goal{width:90px}.form-group{min-width:70px}.icon-btn{padding:6px 8px;font-size:11px}}
