:root{--bg:#0a0e14;--bg-card:#121820;--bg-elevated:#1a222d;--border:#2a3544;--text:#e8edf4;--text-muted:#8b9bb0;--accent:#3dd68c;--accent-dim:#2a9d63;--income:#3dd68c;--expense:#f07178;--warning:#e6b450;--danger:#f07178;--radius:14px;--radius-sm:10px;--nav-height:72px;--safe-bottom:env(safe-area-inset-bottom,0px);--font:"Segoe UI", system-ui, -apple-system, sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-tap-highlight-color:transparent;font-size:16px}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100dvh;line-height:1.5;overflow-x:hidden}#root{min-height:100dvh}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer;background:0 0;border:none}a{color:var(--accent);text-decoration:none}.app-shell{max-width:480px;min-height:100dvh;padding-bottom:calc(var(--nav-height) + var(--safe-bottom) + 16px);margin:0 auto}.page{padding:16px;animation:.2s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.page-header{margin-bottom:20px}.page-header h1{letter-spacing:-.02em;font-size:1.5rem;font-weight:700}.page-header p{color:var(--text-muted);margin-top:4px;font-size:.875rem}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;padding:16px}.card-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:8px;font-size:.75rem}.summary-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.summary-item{background:var(--bg-elevated);border-radius:var(--radius-sm);padding:12px}.summary-item.full{grid-column:1/-1}.summary-item .label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.7rem}.summary-item .value{margin-top:4px;font-size:1.15rem;font-weight:700}.summary-item .value.income{color:var(--income)}.summary-item .value.expense{color:var(--expense)}.summary-item .value.balance-positive{color:var(--accent)}.summary-item .value.balance-negative{color:var(--danger)}.btn{border-radius:var(--radius-sm);justify-content:center;align-items:center;gap:8px;width:100%;min-height:48px;padding:0 20px;font-size:.95rem;font-weight:600;transition:transform .1s,opacity .15s;display:inline-flex}.btn:active{transform:scale(.98)}.btn-primary{background:var(--accent);color:#0a0e14}.btn-primary:hover{background:var(--accent-dim);color:var(--text)}.btn-secondary{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text)}.btn-danger{color:var(--danger);background:#f0717826;border:1px solid #f071784d}.btn-icon{border-radius:50%;flex-shrink:0;width:44px;height:44px;min-height:44px;padding:0}.fab{right:20px;bottom:calc(var(--nav-height) + var(--safe-bottom) + 20px);background:var(--accent);color:#0a0e14;z-index:50;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.75rem;font-weight:300;display:flex;position:fixed;box-shadow:0 4px 20px #3dd68c59}.list-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:14px 0;display:flex}.list-item:last-child{border-bottom:none}.list-item-content{flex:1;min-width:0}.list-item-title{white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.list-item-meta{color:var(--text-muted);margin-top:2px;font-size:.8rem}.list-item-amount{flex-shrink:0;font-size:1rem;font-weight:700}.list-item-amount.income{color:var(--income)}.list-item-amount.expense{color:var(--expense)}.progress-bar{background:var(--bg-elevated);border-radius:4px;height:8px;margin-top:8px;overflow:hidden}.progress-bar-fill{border-radius:4px;height:100%;transition:width .3s,background .3s}.progress-bar-fill.ok{background:var(--accent)}.progress-bar-fill.warning{background:var(--warning)}.progress-bar-fill.danger{background:var(--danger)}.badge{text-transform:uppercase;letter-spacing:.04em;border-radius:6px;padding:3px 8px;font-size:.65rem;font-weight:700;display:inline-block}.badge.ok{color:var(--accent);background:#3dd68c26}.badge.warning{color:var(--warning);background:#e6b45026}.badge.danger{color:var(--danger);background:#f0717826}.badge.recurring{color:#82aaff;background:#82aaff1f}.empty-state{text-align:center;color:var(--text-muted);padding:40px 20px}.empty-state p{margin-top:8px;font-size:.9rem}.form-group{margin-bottom:16px}.form-group label{color:var(--text-muted);margin-bottom:6px;font-size:.8rem;font-weight:500;display:block}.form-group input,.form-group select,.form-group textarea{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;width:100%;min-height:48px;padding:12px 14px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent)}.form-group textarea{resize:vertical;min-height:80px}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-check{align-items:center;gap:10px;min-height:48px;display:flex}.form-check input{width:22px;height:22px;accent-color:var(--accent)}.modal-overlay{z-index:100;background:#000000b3;justify-content:center;align-items:flex-end;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal-sheet{background:var(--bg-card);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-width:480px;max-height:90dvh;padding:20px 16px calc(20px + var(--safe-bottom));animation:.25s slideUp;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:none}}.modal-handle{background:var(--border);border-radius:2px;width:40px;height:4px;margin:0 auto 16px}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-header h2{font-size:1.2rem}.alert-banner{border-radius:var(--radius-sm);align-items:flex-start;gap:10px;margin-bottom:12px;padding:12px 14px;font-size:.85rem;display:flex}.alert-banner.warning{color:var(--warning);background:#e6b4501f;border:1px solid #e6b4504d}.alert-banner.danger{color:var(--danger);background:#f071781f;border:1px solid #f071784d}.chart-bars{align-items:flex-end;gap:8px;height:120px;padding-top:8px;display:flex}.chart-bar-col{flex-direction:column;flex:1;align-items:center;gap:6px;height:100%;display:flex}.chart-bar{border-radius:6px 6px 0 0;width:100%;max-width:48px;min-height:4px;margin-top:auto}.chart-bar.income{background:var(--income)}.chart-bar.expense{background:var(--expense)}.chart-label{color:var(--text-muted);font-size:.65rem}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:4px;font-size:.7rem;display:grid}.calendar-day{aspect-ratio:1;background:var(--bg-elevated);border-radius:8px;flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative}.calendar-day.has-income{box-shadow:inset 0 0 0 2px var(--income)}.calendar-day.has-expense{box-shadow:inset 0 0 0 2px var(--expense)}.calendar-day.both{box-shadow:inset 0 0 0 2px var(--warning)}.month-select{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;min-height:44px;margin-bottom:16px;padding:10px 14px}.entry-card{border-left:4px solid var(--accent)}.entry-card.warning{border-left-color:var(--warning)}.entry-card.danger{border-left-color:var(--danger)}.entry-stats{grid-template-columns:1fr 1fr;gap:8px;margin-top:12px;font-size:.85rem;display:grid}.entry-stat .label{color:var(--text-muted);font-size:.7rem}.entry-stat .value{font-weight:600}.bottom-nav{width:100%;max-width:480px;height:calc(var(--nav-height) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:var(--bg-card);border-top:1px solid var(--border);z-index:40;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.bottom-nav-link{color:var(--text-muted);border-radius:var(--radius-sm);flex-direction:column;align-items:center;gap:4px;min-width:56px;padding:8px 12px;font-size:.65rem;font-weight:600;text-decoration:none;transition:color .15s;display:flex}.bottom-nav-link.active{color:var(--accent)}.bottom-nav-icon{font-size:1.25rem;line-height:1}.bottom-nav-label{letter-spacing:.02em}.actions-row{gap:8px;margin-top:12px;display:flex}.actions-row .btn{flex:1}
