:root{--primary:#336699;--primary-2:#2a5685;--sky:#86bbd8;--ink:#2f4858;--lime:#9ee493;--mint:#daf7dc;--bg:#f4f6f3;--bg-2:#eef1ee;--surface:#ffffff;--ink-90:#2f4858;--ink-70:rgba(47,72,88,.74);--ink-50:rgba(47,72,88,.52);--ink-30:rgba(47,72,88,.3);--ink-15:rgba(47,72,88,.15);--ink-08:rgba(47,72,88,.08);--line:rgba(47,72,88,.12);--primary-08:rgba(51,102,153,.08);--primary-15:rgba(51,102,153,.15);--shadow-sm:0 1px 2px rgba(47,72,88,.06), 0 1px 1px rgba(47,72,88,.04);--shadow-md:0 4px 16px rgba(47,72,88,.08), 0 1px 2px rgba(47,72,88,.05);--shadow-lg:0 18px 50px rgba(47,72,88,.18), 0 6px 16px rgba(47,72,88,.08);--radius-xs:8px;--radius-sm:12px;--radius-md:18px;--radius-lg:24px;--radius-xl:32px;--font-display:"Bricolage Grotesque","Bricolage", system-ui, sans-serif;--font-body:"Manrope", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}html,body{margin:0;padding:0}body{font-family:var(--font-body);color:var(--ink-90);background:radial-gradient(1200px 700px at 80% -10%,#e6efe2 0%,transparent 60%),radial-gradient(900px 500px at -10% 100%,#dbeaf2 0%,transparent 55%),var(--bg);min-height:100vh;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}.app-stage{min-height:100vh;display:flex;justify-content:center;padding:20px 16px 24px}.app-shell{width:100%;max-width:440px;min-height:calc(100vh - 40px);background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden;position:relative;display:flex;flex-direction:column;isolation:isolate}@media(max-width:520px){.app-stage{padding:0}.app-shell{border-radius:0;min-height:100vh;max-width:none;box-shadow:none}}.topbar{position:sticky;top:0;z-index:10;background:#ffffffdb;backdrop-filter:saturate(150%) blur(14px);-webkit-backdrop-filter:saturate(150%) blur(14px);border-bottom:1px solid var(--line);padding:14px 20px 10px;display:flex;align-items:center;justify-content:space-between;gap:12px}.topbar .greet{font-family:var(--font-display);font-weight:600;font-size:18px;letter-spacing:-.01em}.topbar .greet small{font-family:var(--font-body);font-weight:500;font-size:12px;color:var(--ink-50);display:block;margin-top:1px;letter-spacing:0}.topbar .actions{display:flex;gap:6px}.icon-btn{width:38px;height:38px;border-radius:12px;border:1px solid var(--line);background:var(--surface);color:var(--ink-90);display:grid;place-items:center;cursor:pointer;transition:transform .15s ease,background .15s ease;position:relative}.icon-btn:hover{background:var(--ink-08)}.icon-btn:active{transform:scale(.96)}.icon-btn.has-dot:after{content:"";position:absolute;width:8px;height:8px;background:var(--lime);border-radius:50%;border:1.5px solid var(--surface)}.topbar-avatar{text-decoration:none;font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--primary);background:var(--primary-15);border-color:transparent}.screen{flex:1;overflow-y:auto;overflow-x:hidden;padding:16px 20px 110px;scroll-behavior:smooth}.screen::-webkit-scrollbar{width:0}.section-h{display:flex;align-items:baseline;justify-content:space-between;margin:24px 2px 12px}.section-h h2{font-family:var(--font-display);font-weight:600;font-size:22px;letter-spacing:-.015em;margin:0}.section-h .meta{font-family:var(--font-mono);font-size:11px;color:var(--ink-50);letter-spacing:.04em;text-transform:uppercase}.section-h .link{font-size:13px;color:var(--primary);font-weight:600;cursor:pointer}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:16px}.card-soft{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-md);padding:16px}.chip{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:var(--surface);border-radius:999px;padding:5px 10px;font-size:12.5px;font-weight:600;color:var(--ink-90);cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease}.chip:hover{background:var(--ink-08)}.chip.active{background:var(--ink-90);color:#fff;border-color:var(--ink-90)}.chip.lime{background:var(--lime);border-color:var(--lime);color:var(--ink-90)}.chip.mint{background:var(--mint);border-color:transparent;color:var(--ink-90)}.chip.sky{background:var(--sky);border-color:var(--sky);color:#10242f}.chip.primary{background:var(--primary);border-color:var(--primary);color:#fff}.chip.ghost{background:transparent;border:1px dashed var(--ink-30);color:var(--ink-70)}.chip.sm{padding:3px 8px;font-size:11px}.chip .dot{width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.6}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;font-family:var(--font-body);font-weight:700;border-radius:14px;padding:13px 18px;font-size:14px;transition:transform .15s ease,background .15s ease,box-shadow .15s ease}.btn:active{transform:scale(.98)}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 6px 18px #33669947}.btn-primary:hover{background:var(--primary-2)}.btn-ghost{background:transparent;color:var(--ink-90)}.btn-secondary{background:var(--bg-2);color:var(--ink-90);border:1px solid var(--line)}.btn-block{width:100%}.form-field{display:flex;flex-direction:column;gap:8px}.form-label{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-50)}.input{width:100%;border:1px solid var(--line);border-radius:14px;padding:12px 14px;background:var(--surface);color:var(--ink-90);font-family:var(--font-body);font-size:14px;transition:border-color .15s ease,box-shadow .15s ease}.input::placeholder{color:var(--ink-30)}.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-15)}.input:disabled{background:var(--bg-2);color:var(--ink-50)}.form-hint{font-size:12px;color:var(--danger, #c0392b)}.form-error{padding:10px 12px;border-radius:12px;background:#c0392b14;color:var(--danger, #c0392b);border:1px solid rgba(192,57,43,.18);font-size:12.5px}.auth-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 20px}.login-screen{width:100%;max-width:360px}.login-logo{width:52px;height:52px;background:var(--primary);border-radius:16px;display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:18px;color:#fff;letter-spacing:-.02em;margin:0 auto;box-shadow:0 6px 18px #33669947}.login-card{padding:28px;display:flex;flex-direction:column;gap:20px}.login-hero{display:flex;flex-direction:column;gap:6px;text-align:center}.login-hero .kicker{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-50)}.login-hero .title{font-family:var(--font-display);font-size:24px;font-weight:700;letter-spacing:-.02em}.login-hero .sub{font-size:13.5px;color:var(--ink-70)}.login-card form{display:flex;flex-direction:column;gap:14px;width:100%}.kbd-mono{font-family:var(--font-mono);font-size:11px;color:var(--ink-50);letter-spacing:.04em;text-transform:uppercase}.num{font-family:var(--font-display);font-variant-numeric:tabular-nums;letter-spacing:-.02em;font-weight:600;color:var(--ink-90)}.num-mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.story-hero{background:linear-gradient(140deg,var(--primary) 0%,var(--primary-2) 100%);color:#fff;border-radius:var(--radius-lg);padding:22px 20px 20px;box-shadow:0 12px 28px #33669938;position:relative;overflow:hidden}.story-hero:before{content:"";position:absolute;right:-40px;top:-40px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle at 30% 30%,rgba(158,228,147,.35),transparent 65%);pointer-events:none}.story-hero .label{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;opacity:.78}.story-hero .amount{font-family:var(--font-display);font-size:64px;line-height:1;font-weight:700;letter-spacing:-.04em;margin-top:8px;font-variant-numeric:tabular-nums}.story-hero .amount .currency{font-size:32px;font-weight:500;opacity:.7;margin-right:4px;vertical-align:8px}.story-hero .sub{font-size:14px;opacity:.88;margin-top:10px;line-height:1.4}.story-hero .delta{display:inline-flex;align-items:center;gap:6px;background:#9ee49338;color:var(--lime);font-weight:700;padding:4px 10px;border-radius:999px;font-size:12px;margin-top:14px}.story-hero .delta .ar{display:inline-block;transform:translateY(-1px)}.scroll-cue{text-align:center;margin:14px 0 -4px;color:var(--ink-30);font-size:18px}.weeks-list{display:flex;flex-direction:column;gap:10px}.week-row{display:grid;grid-template-columns:64px 1fr auto;gap:12px;align-items:center}.week-row .wlbl{font-family:var(--font-display);font-weight:600;font-size:15px}.week-row .wlbl small{display:block;font-family:var(--font-mono);font-size:10px;color:var(--ink-50);letter-spacing:.04em;margin-top:1px;font-weight:500}.week-row .wtrack{height:10px;border-radius:999px;background:var(--ink-08);position:relative;overflow:hidden}.week-row .wfill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--sky),var(--primary));transition:width .8s cubic-bezier(.2,.8,.2,1)}.week-row .wfill.peak{background:linear-gradient(90deg,var(--lime),#6fc864)}.week-row .wamt{font-family:var(--font-display);font-variant-numeric:tabular-nums;font-size:14px;font-weight:600;letter-spacing:-.01em}.cats-strip{display:grid;grid-template-columns:1fr 1fr;gap:10px}.cat-pill{border-radius:var(--radius-md);padding:14px;border:1px solid var(--line);display:flex;flex-direction:column;gap:4px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.cat-pill:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.cat-pill .row{display:flex;align-items:center;justify-content:space-between}.cat-pill .emoji{font-size:20px}.cat-pill .name{font-weight:700;font-size:13px}.cat-pill .amt{font-family:var(--font-display);font-size:20px;font-weight:600;letter-spacing:-.01em;font-variant-numeric:tabular-nums}.cat-pill .pct{font-family:var(--font-mono);font-size:10px;color:var(--ink-50);letter-spacing:.05em}.cat-pill.b-primary{background:var(--primary-08)}.cat-pill.b-sky{background:#86bbd82e}.cat-pill.b-lime{background:#9ee4933d}.cat-pill.b-mint{background:var(--mint)}.extreme-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.extreme{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);padding:14px;display:flex;flex-direction:column;gap:4px}.extreme .tag{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-50)}.extreme .day{font-family:var(--font-display);font-size:22px;font-weight:600;letter-spacing:-.01em}.extreme .amt{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--primary);font-variant-numeric:tabular-nums}.extreme.low .amt{color:var(--ink-70)}.extreme .merch{font-size:12px;color:var(--ink-50);margin-top:2px}.month-switch{display:flex;align-items:center;justify-content:space-between;background:var(--bg-2);padding:6px;border-radius:14px;border:1px solid var(--line)}.month-switch button{background:transparent;border:none;cursor:pointer;width:34px;height:32px;border-radius:10px;color:var(--ink-70);display:grid;place-items:center}.month-switch button:hover{background:var(--ink-08);color:var(--ink-90)}.month-switch button:disabled{opacity:.4;cursor:not-allowed}.month-switch button:disabled:hover{background:transparent;color:var(--ink-70)}.month-switch .label{font-family:var(--font-display);font-weight:600;font-size:16px}.week-cards{display:flex;flex-direction:column;gap:12px}.week-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .18s ease,box-shadow .18s ease}.week-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.week-card .top{display:flex;align-items:center;justify-content:space-between}.week-card .num-w{font-family:var(--font-display);font-size:22px;font-weight:700;letter-spacing:-.02em}.week-card .range{font-family:var(--font-mono);font-size:11px;color:var(--ink-50);letter-spacing:.05em}.week-card .total{font-family:var(--font-display);font-size:32px;font-weight:700;letter-spacing:-.025em;font-variant-numeric:tabular-nums}.week-card .meta{font-size:12.5px;color:var(--ink-50)}.week-card .cats{display:flex;gap:6px;flex-wrap:wrap}.week-card.hero{background:linear-gradient(140deg,var(--mint),#c9efcc 80%);border-color:transparent}.week-card.hero .badge-peak{display:inline-flex;align-items:center;gap:5px;background:#1c5d33;color:var(--lime);padding:4px 10px;border-radius:999px;font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;font-weight:600}.week-card.partial{background:repeating-linear-gradient(135deg,var(--surface) 0 10px,var(--bg-2) 10px 20px)}.week-card .ministrip{height:6px;border-radius:999px;background:var(--ink-08);overflow:hidden;display:flex}.week-card .ministrip span{height:100%}.donut-hero{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px;display:flex;align-items:center;gap:18px;box-shadow:var(--shadow-sm)}.donut-hero svg{flex:0 0 130px;display:block}.donut-hero .side{display:flex;flex-direction:column;gap:4px;min-width:0}.donut-hero .label{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-50)}.donut-hero .total{font-family:var(--font-display);font-size:30px;font-weight:700;letter-spacing:-.025em;font-variant-numeric:tabular-nums;line-height:1}.donut-hero .tx{font-size:13px;color:var(--ink-70);margin-top:4px}.donut-hero .legend{display:flex;flex-wrap:wrap;gap:4px 10px;margin-top:8px}.cat-list{display:flex;flex-direction:column;gap:8px}.cat-row{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);padding:12px 14px;display:grid;grid-template-columns:36px 1fr auto;gap:12px;align-items:center;cursor:pointer;transition:background .15s ease}.cat-row:hover{background:var(--ink-08)}.cat-row .iconbox{width:36px;height:36px;border-radius:12px;display:grid;place-items:center;font-size:18px}.cat-row .main{display:flex;flex-direction:column;min-width:0;gap:4px}.cat-row .name-row{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.cat-row .name{font-weight:700;font-size:14.5px}.cat-row .amt{font-family:var(--font-display);font-weight:600;font-size:15px;font-variant-numeric:tabular-nums}.cat-row .bar-row{display:flex;align-items:center;gap:8px;height:18px}.cat-row .bar-track{flex:1;height:6px;border-radius:999px;background:var(--ink-08);overflow:hidden}.cat-row .bar-fill{height:100%;border-radius:999px;background:var(--primary);transition:width .8s cubic-bezier(.2,.8,.2,1)}.cat-row .sub{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-50);letter-spacing:.04em}.cat-row .delta{font-family:var(--font-mono);font-size:11px;font-weight:600;padding:3px 8px;border-radius:999px}.cat-row .delta.up{background:#9ee49366;color:#1c5d33}.cat-row .delta.down{background:#86bbd84d;color:#1c4868}.cat-row .delta.flat{background:var(--ink-08);color:var(--ink-70)}.cat-row .sparkbox{display:flex;align-items:center}.diario-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:6px}.timeline{position:relative;margin-top:6px}.timeline:before{content:"";position:absolute;left:11px;top:8px;bottom:8px;width:0;border-left:2px dashed var(--ink-15)}.day-group{position:relative;padding-left:36px;margin-bottom:22px}.day-group:before{content:"";position:absolute;left:4px;top:8px;width:16px;height:16px;border-radius:50%;background:var(--surface);border:2px solid var(--primary);box-shadow:0 0 0 4px var(--surface)}.day-group.peak:before{background:var(--lime);border-color:var(--ink-90)}.day-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:10px}.day-head .date{font-family:var(--font-display);font-size:17px;font-weight:600;letter-spacing:-.01em}.day-head .date small{font-family:var(--font-mono);font-size:10px;font-weight:500;color:var(--ink-50);text-transform:uppercase;letter-spacing:.06em;margin-left:6px}.day-head .total{font-family:var(--font-display);font-size:18px;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.tx-list{display:flex;flex-direction:column;gap:6px}.tx-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:11px 13px;display:grid;grid-template-columns:36px 1fr auto;gap:11px;align-items:center;transition:background .15s ease,transform .15s ease}.tx-card:hover{background:var(--ink-08)}.tx-card .icon{width:36px;height:36px;border-radius:11px;display:grid;place-items:center;font-size:18px;background:var(--bg-2)}.tx-card .main{min-width:0;display:flex;flex-direction:column;gap:2px}.tx-card .merch{font-weight:600;font-size:13.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tx-card .meta{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-50);letter-spacing:.03em;display:flex;align-items:center;gap:6px}.tx-card .meta .dot{width:3px;height:3px;background:var(--ink-30);border-radius:50%;display:inline-block}.tx-card .amt{font-family:var(--font-display);font-weight:600;font-size:14.5px;font-variant-numeric:tabular-nums}.bottom-nav{position:absolute;left:0;right:0;bottom:0;z-index:11;display:grid;grid-template-columns:repeat(4,1fr);padding:8px 8px calc(8px + env(safe-area-inset-bottom));background:#ffffffeb;backdrop-filter:saturate(160%) blur(18px);-webkit-backdrop-filter:saturate(160%) blur(18px);border-top:1px solid var(--line)}.nav-item{background:transparent;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 6px 6px;border-radius:14px;color:var(--ink-50);font-family:var(--font-body);font-size:11px;font-weight:600;transition:color .15s ease,background .15s ease}.nav-item:hover{color:var(--ink-90);background:var(--ink-08)}.nav-item.active{color:var(--primary)}.nav-item .ic{width:22px;height:22px;display:grid;place-items:center}.nav-item.active .ic{background:var(--primary-15);border-radius:8px}.fab{position:absolute;right:18px;bottom:84px;z-index:12;width:54px;height:54px;border-radius:18px;background:var(--ink-90);color:#fff;display:grid;place-items:center;cursor:pointer;border:none;box-shadow:0 14px 30px #2f485859;transition:transform .15s ease}.fab:hover{transform:translateY(-2px)}.fab .badge{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;border-radius:999px;background:var(--lime);color:var(--ink-90);font-family:var(--font-mono);font-size:10px;font-weight:700;display:grid;place-items:center;padding:0 5px;border:2px solid var(--surface)}.sheet-backdrop{position:absolute;inset:0;z-index:20;background:#14212a6b;opacity:0;pointer-events:none;transition:opacity .25s ease}.sheet-backdrop.open{opacity:1;pointer-events:auto}.sheet{position:absolute;left:0;right:0;bottom:0;z-index:21;background:var(--surface);border-radius:24px 24px 0 0;transform:translateY(102%);transition:transform .35s cubic-bezier(.2,.8,.2,1);max-height:88%;display:flex;flex-direction:column;box-shadow:0 -10px 40px #2f48582e}.sheet.open{transform:translateY(0)}.sheet .grab{width:42px;height:5px;background:var(--ink-15);border-radius:999px;margin:10px auto 4px}.sheet header{display:flex;align-items:center;justify-content:space-between;padding:8px 22px 6px}.sheet header h2{font-family:var(--font-display);font-weight:700;font-size:22px;letter-spacing:-.02em;margin:0}.sheet header .clear{font-size:13px;font-weight:600;color:var(--primary);cursor:pointer;background:none;border:none}.sheet .body{padding:6px 22px 8px;overflow-y:auto;display:flex;flex-direction:column;gap:18px}.sheet .field-label{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-50);margin-bottom:8px}.sheet footer{padding:14px 22px calc(18px + env(safe-area-inset-bottom));border-top:1px solid var(--line);background:#fffffff5;-webkit-backdrop-filter:saturate(150%) blur(10px);backdrop-filter:saturate(150%) blur(10px)}.range-track{height:6px;background:var(--ink-08);border-radius:999px;position:relative;margin:18px 4px 8px}.range-track .range-fill{position:absolute;inset:0 32% 0 18%;background:var(--primary);border-radius:999px}.range-track .thumb{position:absolute;top:50%;width:22px;height:22px;border-radius:50%;background:#fff;border:2px solid var(--primary);transform:translate(-50%,-50%);box-shadow:var(--shadow-sm)}.range-labels{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:11px;color:var(--ink-50);font-weight:500}.screen-fade-enter{opacity:0;transform:translateY(6px)}.screen-fade-enter-active{opacity:1;transform:translateY(0);transition:opacity .2s ease,transform .25s ease}.spark{display:block}.s-primary{background:var(--primary)}.s-sky{background:var(--sky)}.s-lime{background:var(--lime)}.s-mint{background:var(--mint)}.muted{color:var(--ink-50)}.right{text-align:right}.hairline{height:1px;background:var(--line);margin:8px 0}.shell-main{display:flex;flex-direction:column;flex:1;min-width:0;overflow:hidden}.side-nav{display:none}@media(min-width:768px){.app-shell{max-width:680px}.cats-strip{grid-template-columns:repeat(3,1fr)}.week-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px}.story-hero .amount{font-size:72px}}@media(min-width:1024px){.app-stage{padding:0;align-items:stretch}.app-shell{max-width:none;border-radius:0;box-shadow:none;flex-direction:row;height:100vh;overflow:hidden}.shell-main{height:100%}.screen{padding:24px 40px 40px}.bottom-nav,.fab{display:none}.side-nav{display:flex;flex-direction:column;width:220px;min-width:220px;height:100%;border-right:1px solid var(--line);background:var(--surface);padding:20px 12px 24px;overflow-y:auto;flex-shrink:0}.side-nav-brand{display:flex;align-items:center;gap:10px;padding:6px 8px 18px;margin-bottom:8px;border-bottom:1px solid var(--line)}.side-nav-logo{width:34px;height:34px;background:var(--primary);border-radius:10px;display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:14px;color:#fff;letter-spacing:-.02em;flex-shrink:0}.side-nav-name{font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:-.025em;color:var(--ink-90)}.side-nav-links{display:flex;flex-direction:column;gap:2px;flex:1;padding-top:6px}.side-nav-item{display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--radius-sm);color:var(--ink-70);font-weight:600;font-size:14px;text-decoration:none;cursor:pointer;transition:background .15s ease,color .15s ease}.side-nav-item:hover{background:var(--ink-08);color:var(--ink-90)}.side-nav-item.active{background:var(--primary-15);color:var(--primary)}.side-nav-ic{width:30px;height:30px;display:grid;place-items:center;border-radius:9px;flex-shrink:0}.side-nav-footer{padding-top:12px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:8px}.side-nav-user{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s ease}.side-nav-user:hover{background:var(--ink-08)}.side-nav-user-avatar{width:28px;height:28px;border-radius:999px;background:var(--primary-15);color:var(--primary);display:grid;place-items:center;font-size:12px;font-weight:700;flex-shrink:0}.side-nav-user-email{font-size:12px;color:var(--ink-50);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.side-nav-filter-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--surface);color:var(--ink-90);font-weight:600;font-size:14px;font-family:var(--font-body);cursor:pointer;transition:background .15s ease}.side-nav-filter-btn:hover{background:var(--ink-08)}.side-nav-filter-btn .badge-inline{margin-left:auto;min-width:20px;height:20px;background:var(--lime);color:var(--ink-90);border-radius:999px;font-family:var(--font-mono);font-size:10px;font-weight:700;display:grid;place-items:center;padding:0 5px}.cats-strip{grid-template-columns:repeat(4,1fr)}.week-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px}.cat-list{display:grid;grid-template-columns:1fr 1fr;gap:8px}.extreme-grid{grid-template-columns:repeat(4,1fr)}.donut-hero{padding:24px 28px}.story-hero .amount{font-size:76px}.btn-block{max-width:360px}}@media(min-width:1440px){.side-nav{width:260px;min-width:260px}.screen{padding:28px 56px 48px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{transition:none!important;animation:none!important}}.icon-edit-trigger{cursor:pointer;transition:transform .15s;-webkit-user-select:none;user-select:none}.icon-edit-trigger:hover{transform:scale(1.2)}.saving{opacity:.45}.cat-select{background:var(--bg-2);border:1px solid var(--lime);border-radius:6px;color:var(--ink-90);font-size:12px;padding:2px 6px;cursor:pointer}
