:root{--bg: #f3f5f8;--surface: #ffffff;--surface-2: #f8fafc;--ink: #0f172a;--ink-soft: #475569;--muted: #94a3b8;--line: #e6eaf0;--line-strong: #d4dbe5;--primary: #10b981;--primary-strong: #059669;--primary-soft: #e7f8f1;--income: #15a34a;--expense: #e11d48;--gold: #d4af37;--sidebar-bg: #0f172a;--sidebar-grad: linear-gradient(180deg, #111c33 0%, #0c1424 100%);--sidebar-ink: #aeb9cc;--sidebar-ink-strong: #f1f5f9;--radius: 14px;--radius-sm: 10px;--radius-lg: 20px;--shadow: 0 1px 2px rgba(15, 23, 42, .05), 0 10px 30px -16px rgba(15, 23, 42, .18);--shadow-soft: 0 1px 2px rgba(15, 23, 42, .04);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--ease: cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--ink);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}h1,h2,h3{margin:0;font-weight:650;letter-spacing:-.01em}a{color:inherit;text-decoration:none}.ff-splash{height:100%;display:grid;place-content:center;justify-items:center;gap:var(--space-5);background:var(--sidebar-grad);color:#fff}.ff-splash__logo{font-size:28px;font-weight:750;letter-spacing:-.02em}.ff-spinner{width:28px;height:28px;border:3px solid rgba(255,255,255,.25);border-top-color:var(--primary);border-radius:50%;animation:ff-spin .7s linear infinite}.ff-spinner--ink{border-color:var(--line-strong);border-top-color:var(--primary)}@keyframes ff-spin{to{transform:rotate(360deg)}}.ff-app{display:grid;grid-template-columns:248px 1fr;min-height:100%}.ff-sidebar{background:var(--sidebar-grad);color:var(--sidebar-ink);padding:var(--space-5) var(--space-4);display:flex;flex-direction:column;gap:var(--space-5);position:sticky;top:0;height:100vh}.ff-sidebar__brand{display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-2)}.ff-sidebar__brand img{width:34px;height:34px;border-radius:9px}.ff-sidebar__brand b{color:var(--sidebar-ink-strong);font-size:18px;font-weight:720;letter-spacing:-.01em}.ff-nav{display:flex;flex-direction:column;gap:2px}.ff-nav__item{display:flex;align-items:center;gap:var(--space-3);padding:10px var(--space-3);border-radius:var(--radius-sm);color:var(--sidebar-ink);font-weight:550;transition:background .15s var(--ease),color .15s var(--ease)}.ff-nav__item span.ico{font-size:18px;width:22px;text-align:center}.ff-nav__item:hover{background:#ffffff0f;color:var(--sidebar-ink-strong)}.ff-nav__item.active{background:#10b98129;color:#fff;box-shadow:inset 3px 0 0 var(--primary)}.ff-sidebar__foot{margin-top:auto;display:flex;flex-direction:column;gap:var(--space-3);font-size:13px}.ff-sidebar__user{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:#ffffff0d;border-radius:var(--radius-sm)}.ff-avatar{width:34px;height:34px;border-radius:50%;display:grid;place-content:center;font-weight:650;color:#fff;background:var(--primary-strong);flex-shrink:0}.ff-main{min-width:0;display:flex;flex-direction:column}.ff-topbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-5) var(--space-6)}.ff-topbar h1{font-size:23px}.ff-topbar__sub{color:var(--muted);font-size:13px;margin-top:2px}.ff-content{padding:0 var(--space-6) var(--space-6);flex:1;width:100%;max-width:1180px}.ff-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:var(--space-5)}.ff-card__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4);gap:var(--space-3)}.ff-card__title{font-size:15px;font-weight:650}.ff-grid{display:grid;gap:var(--space-4)}.ff-grid--stats{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.ff-grid--2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.ff-stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:var(--space-5);box-shadow:var(--shadow-soft)}.ff-stat__label{color:var(--muted);font-size:13px;font-weight:550;display:flex;align-items:center;gap:var(--space-2)}.ff-stat__value{font-size:26px;font-weight:700;letter-spacing:-.02em;margin-top:var(--space-2)}.ff-stat--accent{background:linear-gradient(150deg,#0f172a,#14223d);border-color:transparent;color:#fff}.ff-stat--accent .ff-stat__label{color:#ffffffb3}.t-income{color:var(--income)}.t-expense{color:var(--expense)}.t-muted{color:var(--muted)}.ff-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:10px 16px;border-radius:var(--radius-sm);border:1px solid var(--line-strong);background:var(--surface);color:var(--ink);font-weight:600;font-size:14px;transition:transform .12s var(--ease),background .15s var(--ease),border-color .15s var(--ease)}.ff-btn:hover{background:var(--surface-2)}.ff-btn:active{transform:translateY(1px)}.ff-btn--primary{background:var(--primary);border-color:var(--primary);color:#fff}.ff-btn--primary:hover{background:var(--primary-strong);border-color:var(--primary-strong)}.ff-btn--danger{background:#fff;border-color:#f5c2cd;color:var(--expense)}.ff-btn--danger:hover{background:#fff1f3}.ff-btn--ghost{border-color:transparent;background:transparent}.ff-btn--ghost:hover{background:var(--surface-2)}.ff-btn--sm{padding:6px 11px;font-size:13px}.ff-btn:disabled{opacity:.55;cursor:not-allowed}.ff-btn--block{width:100%}.ff-field{display:flex;flex-direction:column;gap:6px}.ff-label{font-size:13px;font-weight:600;color:var(--ink-soft)}.ff-input,.ff-select,.ff-textarea{width:100%;padding:10px 12px;border:1px solid var(--line-strong);border-radius:var(--radius-sm);background:var(--surface);color:var(--ink);font-size:15px;font-family:inherit;transition:border-color .15s var(--ease),box-shadow .15s var(--ease)}.ff-textarea{resize:vertical;min-height:84px}.ff-input:focus,.ff-select:focus,.ff-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.ff-error{color:var(--expense);font-size:13px}.ff-segment{display:inline-flex;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:3px;gap:3px}.ff-segment button{border:none;background:transparent;padding:7px 14px;border-radius:7px;font-weight:600;font-size:13px;color:var(--ink-soft)}.ff-segment button.active.inc{background:var(--income);color:#fff}.ff-segment button.active.exp{background:var(--expense);color:#fff}.ff-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:13px;font-weight:550;background:var(--surface-2);border:1px solid var(--line)}.ff-chip__dot{width:9px;height:9px;border-radius:50%}.ff-list{display:flex;flex-direction:column}.ff-row{display:flex;align-items:center;gap:var(--space-3);padding:12px 4px;border-bottom:1px solid var(--line)}.ff-row:last-child{border-bottom:none}.ff-row__icon{width:40px;height:40px;border-radius:11px;display:grid;place-content:center;font-size:19px;flex-shrink:0}.ff-row__main{min-width:0;flex:1}.ff-row__title{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ff-row__meta{color:var(--muted);font-size:12.5px;display:flex;gap:8px}.ff-row__amount{font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap}.ff-row__actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.ff-row:hover .ff-row__actions{opacity:1}.ff-progress{height:9px;border-radius:999px;background:var(--line);overflow:hidden}.ff-progress__fill{height:100%;border-radius:999px;background:var(--primary);transition:width .4s var(--ease)}.ff-progress__fill.warn{background:var(--gold)}.ff-progress__fill.over{background:var(--expense)}.ff-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:grid;place-items:center;padding:var(--space-4);z-index:50;animation:ff-fade .15s var(--ease)}.ff-modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:0 24px 64px -20px #0f172a66;width:100%;max-width:460px;max-height:92vh;overflow-y:auto;animation:ff-rise .18s var(--ease)}.ff-modal--wide{max-width:720px}.ff-modal__head{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-5) var(--space-3)}.ff-modal__body{padding:0 var(--space-5) var(--space-5);display:flex;flex-direction:column;gap:var(--space-4)}.ff-modal__foot{display:flex;gap:var(--space-3);justify-content:flex-end}@keyframes ff-fade{0%{opacity:0}}@keyframes ff-rise{0%{opacity:0;transform:translateY(12px)}}.ff-monthnav{display:inline-flex;align-items:center;gap:var(--space-2)}.ff-monthnav b{min-width:130px;text-align:center;font-weight:650}.ff-empty{text-align:center;color:var(--muted);padding:var(--space-6) var(--space-4)}.ff-empty__icon{font-size:34px;margin-bottom:var(--space-2)}.ff-stack{display:flex;flex-direction:column;gap:var(--space-4)}.ff-stack--lg{gap:var(--space-5)}.ff-row-between{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.ff-flex{display:flex;gap:var(--space-3);align-items:center}.ff-wrap{flex-wrap:wrap}.ff-banner{background:var(--primary-soft);border:1px solid #b6ebd8;border-radius:var(--radius);padding:var(--space-3) var(--space-4);color:#0f5132;font-size:13.5px}.ff-banner--warn{background:#fff8e6;border-color:#f3e2b0;color:#7a5b00}.ff-bars{display:flex;align-items:flex-end;gap:var(--space-3);height:180px;padding-top:var(--space-4)}.ff-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end}.ff-bar-stack{display:flex;flex-direction:column-reverse;gap:3px;width:60%;max-width:38px;height:100%;justify-content:flex-end}.ff-bar{border-radius:5px 5px 0 0;min-height:2px}.ff-bar.inc{background:var(--income)}.ff-bar.exp{background:var(--expense)}.ff-bar-label{font-size:11px;color:var(--muted)}.ff-adv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:var(--space-4)}.ff-adv-card{text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:var(--space-4);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:6px;transition:transform .14s var(--ease),box-shadow .14s var(--ease),border-color .14s var(--ease)}.ff-adv-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--line-strong)}.ff-adv-card__icon{font-size:26px}.ff-adv-card__title{font-weight:650}.ff-adv-card__desc{font-size:13px;color:var(--muted)}.ff-adv-result{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:var(--space-5);white-space:pre-wrap;line-height:1.65;font-size:14.5px}.ff-mobnav{display:none}@media(max-width:900px){.ff-app{grid-template-columns:1fr}.ff-sidebar{display:none}.ff-topbar{padding:var(--space-4) var(--space-4) var(--space-3)}.ff-content{padding:0 var(--space-4) 96px}.ff-mobnav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--line);padding:6px 4px calc(6px + env(safe-area-inset-bottom));justify-content:space-around;z-index:40}.ff-mobnav__item{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:10.5px;color:var(--muted);padding:4px 8px;border-radius:9px;min-width:56px}.ff-mobnav__item .ico{font-size:20px}.ff-mobnav__item.active{color:var(--primary-strong)}}@media(prefers-reduced-motion:reduce){*{animation-duration:.001ms!important;transition-duration:.001ms!important}}
