@import"https://fonts.googleapis.com/css2?family=Nunito+Sans:ital,opsz,wght@0,6..12,300;0,6..12,400;0,6..12,600;0,6..12,700;0,6..12,800;1,6..12,400&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f1117;--bg-card: #1a1d27;--bg-input: #242736;--border: #2e3244;--text: #e8eaf0;--text-muted: #8b8fa3;--text-secondary: #9ca3b8;--surface: #1a1d27;--accent: #6c5ce7;--accent-hover: #7e6ff0;--income: #00d084;--income-bg: rgba(0, 208, 132, .12);--expense: #ff6b6b;--expense-bg: rgba(255, 107, 107, .12);--danger: #ff4757;--radius: 14px;--radius-sm: 8px;--shadow: 0 2px 16px rgba(0, 0, 0, .25);--font: "Nunito Sans", system-ui, -apple-system, sans-serif;--transition: .2s ease}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;min-height:100dvh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;max-width:480px;margin:0 auto;padding:0 16px 32px}.app-shell{display:flex;flex-direction:column;gap:16px;padding-top:16px}.hero-card{background:linear-gradient(135deg,#6c5ce7,#4834d4);border-radius:var(--radius);padding:24px 20px 20px;color:#fff;box-shadow:0 4px 24px #6c5ce74d}.month-nav{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:16px}.month-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:50%;background:#ffffff2e;color:#fff;font-size:20px;font-weight:700;cursor:pointer;transition:background var(--transition);line-height:1}.month-btn:hover{background:#ffffff4d}.month-label{font-size:16px;font-weight:600;text-transform:capitalize;min-width:140px;text-align:center}.hero-loading{text-align:center;padding:20px 0;opacity:.7}.balance{font-size:34px;font-weight:800;text-align:center;letter-spacing:-.5px}.balance-sub{text-align:center;font-size:13px;opacity:.7;margin-bottom:16px}.debts-summary{display:flex;flex-wrap:wrap;justify-content:center;gap:12px 20px;font-size:12px;color:var(--text-muted);margin-bottom:12px}.debts-owed-to-me{color:var(--income)}.debts-i-owe{color:var(--expense)}.income-expense-row{display:flex;gap:12px}.ie-block{flex:1;background:#ffffff1f;border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:2px}.ie-label{font-size:12px;opacity:.8;font-weight:600}.ie-value{font-size:17px;font-weight:700}.ie-block.income .ie-value{color:#a0ffc8}.ie-block.expense .ie-value{color:#ffb3b3}.tab-bar{display:flex;gap:0;background:var(--surface);border-radius:var(--radius);padding:4px;margin-bottom:16px;box-shadow:0 1px 3px #0000000f}.tab-bar .tab{flex:1;padding:10px 16px;border:none;border-radius:calc(var(--radius) - 2px);background:transparent;font-size:14px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:background var(--transition),color var(--transition)}.tab-bar .tab:hover{color:var(--text);background:#0000000a}.tab-bar .tab.active{background:#fff;color:var(--text);box-shadow:0 1px 3px #00000014}.debts-placeholder{padding:24px 16px;text-align:center;background:var(--surface);border-radius:var(--radius)}.debts-placeholder .loading-text,.debts-placeholder .empty-hint{margin:0;font-size:14px;color:var(--text-secondary)}.toast-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;width:calc(100% - 32px);max-width:460px;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;box-shadow:0 4px 20px #00000059;pointer-events:auto;animation:toast-in .25s ease-out}.toast--error{background:var(--expense-bg);color:var(--expense);border:1px solid rgba(255,107,107,.25)}.toast--success{background:var(--income-bg);color:var(--income);border:1px solid rgba(0,208,132,.25)}.toast--info{background:var(--bg-card);color:var(--text);border:1px solid var(--border)}.toast__message{flex:1}.toast__close{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:none;border-radius:4px;background:transparent;color:inherit;opacity:.6;font-size:11px;cursor:pointer;transition:opacity var(--transition);flex-shrink:0}.toast__close:hover{opacity:1}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.panel{background:var(--bg-card);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.panel-title{font-size:16px;font-weight:700;margin-bottom:16px;color:var(--text)}.stats-content{display:flex;flex-direction:column;align-items:center;gap:20px}.donut-wrapper{display:flex;justify-content:center}.donut{width:160px;height:160px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative}.donut-hole{width:100px;height:100px;border-radius:50%;background:var(--bg-card);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--text);text-align:center;line-height:1.2}.cat-list{list-style:none;width:100%;display:flex;flex-direction:column;gap:10px}.cat-item{display:flex;align-items:center;gap:8px;font-size:14px}.cat-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.cat-icon{font-size:16px;flex-shrink:0}.cat-name{flex:1;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cat-amount{font-weight:700;white-space:nowrap}.cat-pct{font-size:12px;color:var(--text-muted);min-width:32px;text-align:right}.tx-form{display:flex;flex-direction:column;gap:12px}.form-row{display:flex;gap:8px}.type-toggle,.direction-toggle{background:var(--bg-input);border-radius:var(--radius-sm);padding:4px}.toggle-btn{flex:1;border:none;border-radius:6px;padding:8px 12px;font-size:14px;font-weight:600;font-family:var(--font);background:transparent;color:var(--text-muted);cursor:pointer;transition:all var(--transition)}.toggle-btn.active.expense{background:var(--expense-bg);color:var(--expense)}.toggle-btn.active.income{background:var(--income-bg);color:var(--income)}.toggle-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.form-input{flex:1;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;font-size:14px;font-family:var(--font);color:var(--text);outline:none;transition:border-color var(--transition);width:100%;-moz-appearance:none;appearance:none;-webkit-appearance:none}.form-input:focus{border-color:var(--accent)}.form-input::placeholder{color:var(--text-muted)}select.form-input{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%238b8fa3' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.form-message{padding:10px 14px;border-radius:var(--radius-sm);font-size:14px;width:100%}.form-message--error{background:color-mix(in srgb,var(--error, #c62828) 15%,transparent);border:1px solid var(--error, #c62828);color:var(--text)}.form-hint{display:block;margin-top:6px;font-size:12px;color:var(--text-muted)}.submit-btn{border:none;border-radius:var(--radius-sm);padding:12px;font-size:15px;font-weight:700;font-family:var(--font);background:var(--accent);color:#fff;cursor:pointer;transition:background var(--transition),opacity var(--transition)}.submit-btn:hover:not(:disabled){background:var(--accent-hover)}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.submit-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.cancel-btn{border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;font-size:15px;font-weight:600;font-family:var(--font);background:var(--bg-input);color:var(--text-muted);cursor:pointer;transition:all var(--transition);flex-shrink:0}.cancel-btn:hover{background:var(--border);color:var(--text)}.cancel-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.form-actions{display:flex;gap:10px;align-items:center}.form-actions .submit-btn{flex:1}.stats-header{margin-bottom:16px}.stats-toggle{background:var(--bg-input);border-radius:var(--radius-sm);padding:4px;display:flex;gap:0}.stats-toggle-btn{flex:1;border:none;border-radius:6px;padding:8px 12px;font-size:14px;font-weight:600;font-family:var(--font);background:transparent;color:var(--text-muted);cursor:pointer;transition:all var(--transition)}.stats-toggle-btn.active.expense{background:var(--expense-bg);color:var(--expense)}.stats-toggle-btn.active.income{background:var(--income-bg);color:var(--income)}.stats-toggle-btn:hover:not(.active){color:var(--text)}.stats-toggle-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.tx-list{list-style:none;display:flex;flex-direction:column;gap:10px}.tx-card{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-input);border-radius:10px;transition:background var(--transition)}.tx-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.tx-info{flex:1;display:flex;flex-direction:column;min-width:0}.tx-desc{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tx-date{font-size:12px;color:var(--text-muted)}.tx-desc-secondary{font-size:12px;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.debt-direction.owed_to_me{background:var(--income);color:#fff}.debt-direction.i_owe{background:var(--expense);color:#fff}.tx-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.tx-amount{font-size:14px;font-weight:700;white-space:nowrap}.tx-amount.income{color:var(--income)}.tx-amount.expense{color:var(--expense)}.tx-delete{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:6px;background:transparent;color:var(--text-muted);font-size:12px;cursor:pointer;transition:all var(--transition)}.tx-edit{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:6px;background:transparent;color:var(--text-muted);font-size:14px;cursor:pointer;transition:all var(--transition)}.tx-edit:hover{background:var(--bg-card);color:var(--accent)}.tx-edit:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.tx-delete:hover{background:var(--expense-bg);color:var(--danger)}.tx-delete:focus-visible{outline:2px solid var(--danger);outline-offset:2px}.muted{color:var(--text-muted);font-size:14px;text-align:center;padding:20px 0}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;background:#0009;display:flex;align-items:center;justify-content:center;animation:confirm-fade-in .15s ease-out}.confirm-modal{background:var(--bg-card);border-radius:var(--radius);padding:24px;width:calc(100% - 32px);max-width:360px;box-shadow:0 8px 32px #00000073;animation:confirm-slide-in .2s ease-out}.confirm-modal__title{font-size:17px;font-weight:700;margin-bottom:8px;color:var(--text)}.confirm-modal__message{font-size:14px;color:var(--text-muted);margin-bottom:20px;line-height:1.5}.confirm-modal__actions{display:flex;gap:10px;justify-content:flex-end}.confirm-modal__btn{border:none;border-radius:var(--radius-sm);padding:10px 20px;font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer;transition:background var(--transition),opacity var(--transition)}.confirm-modal__btn--cancel{background:var(--bg-input);color:var(--text-muted)}.confirm-modal__btn--cancel:hover{background:var(--border);color:var(--text)}.confirm-modal__btn--confirm{background:var(--danger);color:#fff}.confirm-modal__btn--confirm:hover{opacity:.85}@keyframes confirm-fade-in{0%{opacity:0}to{opacity:1}}@keyframes confirm-slide-in{0%{opacity:0;transform:translateY(-12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{display:inline-block;background:linear-gradient(90deg,#ffffff0a 25%,#ffffff1a,#ffffff0a 75%);background-size:800px 100%;animation:shimmer 1.6s ease-in-out infinite;border-radius:var(--radius-sm);line-height:1;vertical-align:middle}.skeleton--text{width:100%;height:1em;border-radius:4px}.skeleton--circle{border-radius:50%;flex-shrink:0}.hero-card .skeleton{background:linear-gradient(90deg,#ffffff1a 25%,#ffffff38,#ffffff1a 75%);background-size:800px 100%;animation:shimmer 1.6s ease-in-out infinite}.skeleton-cat-row{display:flex;align-items:center;gap:8px}.skeleton-tx-card{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-input);border-radius:10px}.skeleton-tx-info{flex:1;display:flex;flex-direction:column;gap:6px}@media (min-width: 481px){#root{padding:0 24px 40px}.app-shell{gap:20px;padding-top:24px}.hero-card{padding:28px 24px 24px}.balance{font-size:40px}.stats-content{flex-direction:row;align-items:flex-start}.donut-wrapper{flex-shrink:0}.donut{width:180px;height:180px}.donut-hole{width:112px;height:112px;font-size:15px}}@media (min-width: 768px){#root{max-width:560px}}
