@import "https://fonts.googleapis.com/css2?family=Bungee&family=Merriweather+Sans:ital,wght@0,300..800;1,300..800&family=Roboto:ital,wght@0,100..900;1,100..900&display=swap";*{box-sizing:border-box;margin:0;padding:0;font-family:Roboto,Merriweather Sans,sans-serif}body{background-color:#28282b}.txt-income{color:green}.txt-expense{color:red}.budget-summary{background-color:#1e1e21;border-bottom:1px solid #2e2e32;justify-content:center;align-items:center;padding:14px 32px;display:flex;box-shadow:0 2px 6px #0000004d}.summary-stat{flex-direction:column;gap:4px;padding:4px 48px;display:flex}.stat-label{color:#9e9e9e;letter-spacing:.06em;text-transform:uppercase;font-family:Roboto,sans-serif;font-size:.75rem;font-weight:400}.stat-value{color:#f8d63e;font-family:Merriweather Sans,sans-serif;font-size:1.8rem;font-weight:700;line-height:1.1}.stat-value.txt-income{color:#4caf50}.stat-value.txt-expense{color:#f44336}.summary-divider{background-color:#2e2e32;flex-shrink:0;width:1px;height:44px}@media (width<=480px){.budget-summary{flex-wrap:wrap;gap:12px;padding:10px 16px}.summary-divider{display:none}.summary-stat{flex:calc(50% - 12px);padding:4px 8px}.stat-value{font-size:1.4rem}}.header{background-color:#f8d63e;flex-wrap:wrap;justify-content:space-between;align-items:center;padding:10px 24px;display:flex;box-shadow:0 3px 8px #00000059}.header-left{align-items:center;gap:12px;display:flex}.header-logo{width:auto;height:70px}.header-title h1{color:#1a1a1a;font-family:Bungee,sans-serif;font-size:1.6rem;line-height:1.1}.header-subtitle{color:#3d3b3b;letter-spacing:.04em;margin-top:2px;font-family:Merriweather Sans,sans-serif;font-size:.8rem;font-weight:400}.header-right{align-items:center;display:flex}.header-date{color:#1a1a1a;letter-spacing:.03em;border-top:2px solid #1a1a1a;border-bottom:2px solid #1a1a1a;padding:6px 18px;font-family:Bungee,sans-serif;font-size:1rem}@media (width<=480px){.header{gap:10px;padding:8px 14px}.header-logo{height:48px}.header-title h1{font-size:1.2rem}.header-subtitle{font-size:.7rem}.header-date{padding:4px 10px;font-size:.85rem}}.transaction-form{padding:1.25rem 1rem 2rem}.transaction-form-card{background:linear-gradient(#ffffff0a,#ffffff05),#2f2f33;border:1px solid #ffffff1f;border-radius:1.1rem;max-width:1100px;margin:0 auto;padding:1.2rem;box-shadow:0 18px 40px #0000002e}.transaction-form-copy{color:#f5f7fb;margin-bottom:1rem}.transaction-form-kicker{letter-spacing:.12em;text-transform:uppercase;color:#8fb6ff;margin-bottom:.3rem;font-size:.72rem;font-weight:700}.transaction-form-copy h2{font-size:1.35rem;font-weight:700}.transaction-form-subtitle{color:#ffffffb3;margin-top:.35rem;font-size:.95rem}.transaction-form-fields{grid-template-columns:minmax(0,2fr) minmax(170px,1.1fr) minmax(150px,.9fr) minmax(140px,.85fr) auto;align-items:start;gap:.85rem;display:grid}.field-group{gap:.42rem;min-width:0;display:grid}.transaction-form input,.transaction-form select{color:#f8fafc;background:#1213188c;border:1px solid #ffffff24;border-radius:.9rem;outline:none;width:100%;height:3.35rem;padding:0 1rem;font-size:1rem;transition:border-color .18s,box-shadow .18s,background-color .18s}.transaction-form input::placeholder{color:#ebeff580}.transaction-form input:focus,.transaction-form select:focus{background:#121318c7;border-color:#8fb6fff2;box-shadow:0 0 0 4px #8fb6ff24}.transaction-form input.has-error{border-color:#ff7e7ef2;box-shadow:0 0 0 4px #ff7e7e1f}.field-error{color:#ffb3b3;padding-left:.2rem;font-size:.82rem;line-height:1.35}.transaction-form select{appearance:none;cursor:pointer}.transaction-submit-btn{color:#16181d;white-space:nowrap;cursor:pointer;background:linear-gradient(135deg,#f7f8fa,#d9deea);border:0;border-radius:.9rem;justify-content:center;align-self:start;align-items:center;gap:.45rem;height:3.35rem;padding:0 1.1rem;font-size:1rem;font-weight:700;transition:transform .18s,box-shadow .18s,filter .18s;display:inline-flex}.transaction-submit-btn:hover{filter:brightness(1.02);transform:translateY(-1px);box-shadow:0 12px 26px #d9deea33}.transaction-submit-btn:active{transform:translateY(0)}.transaction-submit-icon{justify-content:center;align-items:center;width:1.2rem;font-size:1.15rem;line-height:1;display:inline-flex}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (width<=860px){.transaction-form-fields{grid-template-columns:repeat(2,minmax(0,1fr))}.field-group-description,.field-group-category,.transaction-submit-btn{grid-column:span 2}.transaction-submit-btn{width:100%}}@media (width<=560px){.transaction-form{padding:1rem .85rem 1.5rem}.transaction-form-card{border-radius:1rem;padding:1rem}.transaction-form-copy h2{font-size:1.15rem}.transaction-form-fields{grid-template-columns:1fr}.field-group-description,.transaction-submit-btn{grid-column:auto}}.transaction-list{padding:0 1rem 2.2rem}.transaction-list-header{background:linear-gradient(#ffffff0a,#ffffff05),#2f2f33;border:1px solid #ffffff1f;border-bottom:0;border-radius:1.1rem 1.1rem 0 0;justify-content:space-between;align-items:center;gap:.9rem;max-width:1100px;margin:0 auto;padding:1rem 1.35rem;display:flex}.transaction-list-header h2{color:#f5f7fb;font-size:1.25rem}.transaction-list-controls{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.75rem;display:inline-flex}.filter-transaction{align-items:center;gap:.5rem;display:inline-flex}.transaction-sort-control{color:#f5f7fbd1;align-items:center;gap:.5rem;font-size:.88rem;font-weight:600;display:inline-flex}.transaction-sort-control select{color:#f5f7fb;cursor:pointer;background:#12131866;border:1px solid #ffffff24;border-radius:999px;outline:none;min-width:150px;height:2.2rem;padding:0 .75rem;font-size:.88rem;font-weight:600}.transaction-sort-control select:focus{border-color:#8fb6fff2;box-shadow:0 0 0 4px #8fb6ff24}.filter-btn{color:#f5f7fbbf;cursor:pointer;background:#12131866;border:1px solid #ffffff24;border-radius:999px;padding:.42rem .85rem;font-size:.88rem;font-weight:600;transition:border-color .18s,color .18s,background-color .18s,transform .18s}.filter-btn:hover{color:#f5f7fb;border-color:#ffffff4d;transform:translateY(-1px)}.filter-btn.is-active{color:#111520;background:linear-gradient(135deg,#d8e6ff,#b2d0ff);border-color:#b2d0fff2}.reset-btn{color:#f44336;cursor:pointer;background:#f443361a;border:1px solid #f4433673;border-radius:999px;padding:.42rem .85rem;font-size:.88rem;font-weight:600;transition:border-color .18s,background-color .18s,transform .18s}.reset-btn:hover:not(:disabled){background:#f4433638;border-color:#f44336;transform:translateY(-1px)}.reset-btn:disabled{opacity:.35;cursor:not-allowed}.transaction-list-cards{background:linear-gradient(#ffffff05,#ffffff03),#2f2f33;border:1px solid #ffffff1f;border-top:0;border-radius:0 0 1.1rem 1.1rem;max-width:1100px;margin:0 auto;overflow:hidden}.transaction-list-card{border-top:1px solid #ffffff14;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:.75rem;padding:1.05rem 1.35rem;display:grid}.transaction-list-card:first-child{border-top:0}.transaction-list-main{align-items:center;gap:.85rem;min-width:0;display:flex}.transaction-thumbnail{color:#2b364f;background:#f1e8db;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:2.25rem;height:2.25rem;font-weight:700;display:inline-flex}.transaction-meta{min-width:0}.transaction-description{color:#f6f8fc;white-space:nowrap;text-overflow:ellipsis;font-size:1.02rem;font-weight:700;overflow:hidden}.transaction-date{color:#f5f7fbb8;margin-top:.18rem;font-size:.9rem}.transaction-list-side{align-items:center;gap:.8rem;display:flex}.transaction-category{color:#f5f7fbd1;white-space:nowrap;border:1px solid #ffffff24;border-radius:999px;padding:.22rem .62rem;font-size:.83rem;font-weight:600}.transaction-amount{letter-spacing:.01em;text-align:right;min-width:132px;font-size:1.35rem;font-weight:800}.transaction-amount.is-income{color:#4caf50}.transaction-amount.is-expense{color:#f44336}.transaction-row-actions{align-items:center;gap:.35rem;display:inline-flex}.transaction-edit-btn,.transaction-remove-btn{color:#f5f7fb8c;cursor:pointer;background:0 0;border:0;border-radius:.45rem;padding:.38rem .5rem;font-size:.9rem;font-weight:600;line-height:1;transition:color .18s,background-color .18s}.transaction-remove-btn{font-size:1.2rem}.transaction-edit-btn:hover,.transaction-remove-btn:hover{color:#f5f7fb;background:#ffffff14}.transaction-empty-state{color:#f5f7fbc2;text-align:center;padding:1.45rem;font-size:.95rem}.transaction-edit-modal-overlay{z-index:1000;background:#06080cb8;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.transaction-edit-modal{background:linear-gradient(#ffffff0d,#ffffff05),#2f2f33;border:1px solid #ffffff24;border-radius:1rem;width:min(520px,100%);overflow:hidden;box-shadow:0 28px 60px #00000057}.transaction-edit-modal-header{border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;padding:1rem 1rem .85rem;display:flex}.transaction-edit-modal-header h3{color:#f5f7fb;font-size:1.1rem}.transaction-edit-modal-close{color:#f5f7fba6;cursor:pointer;background:0 0;border:0;border-radius:.45rem;padding:.25rem .4rem;font-size:1.2rem}.transaction-edit-modal-close:hover{color:#f5f7fb;background:#ffffff14}.transaction-edit-form{gap:.55rem;padding:1rem;display:grid}.transaction-edit-form label{color:#f5f7fbd1;font-size:.88rem;font-weight:600}.transaction-edit-form input,.transaction-edit-form select{color:#f8fafc;background:#1213189e;border:1px solid #ffffff29;border-radius:.75rem;outline:none;width:100%;height:2.85rem;padding:0 .85rem;font-size:.95rem}.transaction-edit-form input:focus,.transaction-edit-form select:focus{border-color:#8fb6fff2;box-shadow:0 0 0 4px #8fb6ff24}.transaction-edit-form-error{color:#ff9b9b;margin-top:.2rem;font-size:.88rem}.transaction-edit-form-actions{justify-content:flex-end;gap:.6rem;margin-top:.5rem;display:flex}.transaction-edit-cancel,.transaction-edit-save{cursor:pointer;border:1px solid #ffffff24;border-radius:.75rem;padding:.55rem .85rem;font-size:.9rem;font-weight:600}.transaction-edit-cancel{color:#f5f7fbdb;background:0 0}.transaction-edit-save{color:#111520;background:linear-gradient(135deg,#d8e6ff,#b2d0ff);border-color:#b2d0fff2}.transaction-edit-cancel:hover,.transaction-edit-save:hover{transform:translateY(-1px)}@media (width<=860px){.transaction-list-card{grid-template-columns:1fr auto;row-gap:.55rem}.transaction-row-actions{justify-self:end}}@media (width<=560px){.transaction-list{padding:0 .85rem 1.5rem}.transaction-list-header{flex-direction:column;align-items:flex-start;padding:1rem}.transaction-list-controls{justify-content:stretch;width:100%}.filter-transaction{grid-template-columns:repeat(3,minmax(0,1fr));width:100%;display:grid}.transaction-sort-control{justify-content:space-between;width:100%}.transaction-sort-control select{width:100%;min-width:0;max-width:190px}.filter-btn{width:100%}.transaction-list-card{grid-template-columns:1fr;gap:.6rem;padding:.9rem 1rem}.transaction-list-side{justify-content:space-between}.transaction-amount{min-width:0;font-size:1.2rem}.transaction-row-actions{justify-self:start}}
