:root{--grad-1: linear-gradient(135deg, #7c5cff 0%, #22d3ee 100%);--grad-warm: linear-gradient(135deg, #f97316 0%, #facc15 100%);--grad-cool: linear-gradient(135deg, #22d3ee 0%, #34d399 100%);--bg: #f3f5f9;--bg-elev: #ffffff;--surface: rgba(15, 23, 42, .04);--surface-strong: rgba(15, 23, 42, .08);--border: rgba(15, 23, 42, .1);--border-strong: rgba(15, 23, 42, .18);--track: rgba(15, 23, 42, .08);--text: #11161e;--text-muted: #4b5363;--text-subtle: #6b7383;--good: #16a34a;--warn: #d97706;--bad: #dc2626;--shadow-1: 0 1px 2px rgba(15,23,42,.06), 0 8px 24px rgba(15,23,42,.06);--shadow-2: 0 12px 40px rgba(15,23,42,.18);color-scheme:light;--r-1: 6px;--r-2: 10px;--r-3: 14px;--r-4: 20px;--r-pill: 999px;--s-0: 4px;--s-1: 8px;--s-2: 12px;--s-3: 16px;--s-4: 24px;--s-5: 32px;--s-6: 48px;--font-sans: -apple-system, BlinkMacSystemFont, "Inter", "Segoe UI", Roboto, Oxygen, Ubuntu, sans-serif;--font-mono: ui-monospace, SFMono-Regular, "JetBrains Mono", Menlo, monospace;--fs-xs: 11px;--fs-sm: 13px;--fs-md: 15px;--fs-lg: 18px;--fs-xl: 22px;--fs-2xl: 28px;--fs-3xl: 38px;--fs-4xl: 56px;--container-max: 720px;--bp-sm: 480px;--bp-md: 720px;--bp-lg: 1024px}:root[data-theme=dark]{--bg: #1f232c;--bg-elev: #272c37;--surface: rgba(255, 255, 255, .045);--surface-strong: rgba(255, 255, 255, .09);--border: rgba(255, 255, 255, .1);--border-strong: rgba(255, 255, 255, .2);--track: rgba(255, 255, 255, .08);--text: #eef0f5;--text-muted: #a8b0bd;--text-subtle: #7a8290;--good: #34d399;--warn: #facc15;--bad: #ef4444;--shadow-1: 0 1px 2px rgba(0,0,0,.3), 0 8px 24px rgba(0,0,0,.25);--shadow-2: 0 10px 40px rgba(0,0,0,.45);color-scheme:dark}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font-sans);font-size:var(--fs-md);line-height:1.5;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overscroll-behavior-y:none;touch-action:manipulation;-webkit-text-size-adjust:100%;text-size-adjust:100%}button,a,[role=button]{touch-action:manipulation}button{font:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer}input,select,textarea{font:inherit;color:inherit}a{color:inherit;text-decoration:none}h1,h2,h3,h4,p{margin:0}ul{margin:0;padding:0;list-style:none}::selection{background:#7c5cff73}.container{width:100%;max-width:var(--container-max);margin:0 auto;padding-inline:var(--s-3)}@media (min-width: 720px){.container{padding-inline:var(--s-4)}}.stack{display:flex;flex-direction:column;gap:var(--s-3)}.stack-sm{display:flex;flex-direction:column;gap:var(--s-1)}.stack-lg{display:flex;flex-direction:column;gap:var(--s-4)}.row{display:flex;align-items:center;gap:var(--s-2)}.row-between{display:flex;align-items:center;justify-content:space-between;gap:var(--s-2)}.spacer{flex:1}.muted{color:var(--text-muted)}.subtle{color:var(--text-subtle)}.eyebrow{font-size:var(--fs-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--text-subtle);font-weight:600}.section-title{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--s-2)}.section-title h2{font-size:var(--fs-lg);font-weight:600;letter-spacing:-.01em}.app-shell{min-height:100dvh;padding-top:max(env(safe-area-inset-top),var(--s-3));padding-bottom:calc(env(safe-area-inset-bottom) + 96px)}.app-header{padding-block:var(--s-3) var(--s-4)}.app-header h1{font-size:var(--fs-2xl);font-weight:700;letter-spacing:-.02em;background:var(--grad-1);-webkit-background-clip:text;background-clip:text;color:transparent}.tier-1{display:grid;grid-template-columns:1fr;gap:var(--s-3)}.tier-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--s-2)}@media (min-width: 720px){.tier-2{grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--s-3)}}.fab{position:fixed;right:max(var(--s-3),env(safe-area-inset-right));bottom:calc(env(safe-area-inset-bottom) + var(--s-4));z-index:20}.btn{--btn-bg: var(--surface);--btn-fg: var(--text);--btn-bd: var(--border);display:inline-flex;align-items:center;justify-content:center;gap:var(--s-1);padding:10px 14px;border-radius:var(--r-2);background:var(--btn-bg);color:var(--btn-fg);border:1px solid var(--btn-bd);font-weight:600;font-size:var(--fs-sm);transition:transform 80ms ease,background .12s ease,border-color .12s ease;-webkit-tap-highlight-color:transparent}.btn:active{transform:scale(.98)}.btn[data-variant=primary]{--btn-bg: var(--grad-1);--btn-bd: transparent;color:#0b0d10}.btn[data-variant=ghost]{--btn-bg: transparent;--btn-bd: transparent;color:var(--text-muted)}.btn[data-variant=ghost]:hover{color:var(--text)}.btn[data-variant=danger]{--btn-bg: color-mix(in oklch, var(--bad) 14%, transparent);--btn-bd: color-mix(in oklch, var(--bad) 40%, transparent);color:var(--bad)}.btn[data-size=sm]{padding:6px 10px;font-size:var(--fs-xs)}.btn[data-size=lg]{padding:14px 18px;font-size:var(--fs-md)}.btn-icon{width:40px;height:40px;border-radius:var(--r-pill);padding:0}.btn-fab{width:60px;height:60px;border-radius:var(--r-pill);background:var(--grad-1);color:#0b0d10;border:0;box-shadow:var(--shadow-2);display:inline-flex;align-items:center;justify-content:center;font-size:28px;font-weight:700}.btn-fab:active{transform:scale(.96)}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--r-pill);font-size:var(--fs-xs);font-weight:600;background:var(--surface);border:1px solid var(--border);color:var(--text-muted)}.chip[data-tone=up]{color:var(--good);border-color:color-mix(in oklch,var(--good) 38%,transparent);background:color-mix(in oklch,var(--good) 14%,transparent)}.chip[data-tone=down]{color:var(--bad);border-color:color-mix(in oklch,var(--bad) 38%,transparent);background:color-mix(in oklch,var(--bad) 14%,transparent)}.chip[data-tone=flat]{color:var(--text-muted)}.chip[data-tone=cat]{color:var(--cat-color, var(--text));border-color:color-mix(in oklch,var(--cat-color, var(--border)) 40%,transparent);background:color-mix(in oklch,var(--cat-color, transparent) 14%,transparent)}.card{position:relative;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-3);overflow:hidden;isolation:isolate}.card:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;background:radial-gradient(120% 100% at 0% 0%,color-mix(in oklch,var(--cat-color, transparent) 18%,transparent),transparent 60%);pointer-events:none;z-index:0}.card>*{position:relative;z-index:1}.tier1-card{padding:var(--s-4);display:grid;grid-template-columns:minmax(0,1fr) auto;gap:var(--s-3);align-items:center;min-height:168px}.tier1-card .meta{display:flex;flex-direction:column;gap:6px;min-width:0}.tier1-card .name{font-size:var(--fs-lg);font-weight:600;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tier1-card .value{display:flex;align-items:baseline;gap:8px;font-variant-numeric:tabular-nums}.tier1-card .value .num{font-size:var(--fs-3xl);font-weight:700;letter-spacing:-.03em}.tier1-card .value .unit{color:var(--text-muted);font-weight:600}.meta-suffix{color:var(--text-muted);font-weight:600;font-size:var(--fs-md);letter-spacing:-.005em;margin-left:4px}.meta-suffix[data-size=sm]{font-size:var(--fs-xs)}.tier1-card .footer{display:flex;align-items:center;gap:var(--s-2);flex-wrap:wrap}.tier2-card{padding:var(--s-3);display:flex;flex-direction:column;gap:var(--s-1);min-height:116px}.tier2-card .name{font-size:var(--fs-sm);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600}.tier2-card .value .num{font-size:var(--fs-xl);font-weight:700;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.tier2-card .value .unit{font-size:var(--fs-xs);color:var(--text-subtle);margin-left:4px;font-weight:600}.tier2-card .bar{margin-top:auto}.card-clickable{cursor:pointer;transition:transform .1s ease,border-color .12s ease}.card-clickable:hover{border-color:var(--border-strong)}.card-clickable:active{transform:scale(.99)}.empty{text-align:center;padding:var(--s-5) var(--s-3);border:1px dashed var(--border);border-radius:var(--r-3);color:var(--text-muted)}.empty h3{margin-bottom:var(--s-1);color:var(--text);font-weight:600}.bar{width:100%;height:6px;border-radius:var(--r-pill);background:var(--track);overflow:hidden}.bar>span{display:block;height:100%;border-radius:inherit;background:var(--cat-color, var(--text));transition:width .24s ease}.sparkline{width:100%;height:56px;display:block}.sparkline path.line{fill:none;stroke:var(--cat-color, currentColor);stroke-width:2;stroke-linejoin:round;stroke-linecap:round}.sparkline path.fill{fill:var(--cat-color, currentColor);opacity:.18}.sparkline circle{fill:var(--cat-color, currentColor)}.ring{width:112px;height:112px}.ring .track{stroke:var(--track)}.ring .indicator{stroke:var(--cat-color, currentColor);transition:stroke-dashoffset .32s ease}.ring text{fill:var(--text);font-size:18px;font-weight:700;font-family:var(--font-sans);font-variant-numeric:tabular-nums}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:50;animation:overlay-in .16s ease}.dialog-content{position:fixed;z-index:60;background:var(--bg-elev);color:var(--text);left:0;right:0;bottom:0;border-top-left-radius:var(--r-4);border-top-right-radius:var(--r-4);border:1px solid var(--border);padding:0 var(--s-4) calc(env(safe-area-inset-bottom) + var(--s-4));max-height:92dvh;overflow:auto;animation:sheet-in .24s cubic-bezier(.2,.8,.2,1);transform:translateY(var(--sheet-y, 0));touch-action:pan-y;overscroll-behavior:contain}.dialog-content.is-snapping{transition:transform .22s cubic-bezier(.2,.8,.2,1)}@media (min-width: 720px){.dialog-content{left:50%;bottom:auto;top:50%;transform:translate(-50%,calc(-50% + var(--sheet-y, 0px)));width:min(560px,92vw);border-radius:var(--r-3);animation:dialog-in .18s ease;padding:0 var(--s-4) var(--s-4)}.dialog-content.is-snapping{transition:transform .18s ease}}.dialog-handle-area{position:sticky;top:0;z-index:2;display:flex;justify-content:center;align-items:center;padding:14px 0 10px;margin:0 calc(-1 * var(--s-4));background:linear-gradient(to bottom,var(--bg-elev) 70%,transparent);cursor:grab;touch-action:none}.dialog-handle-area:active{cursor:grabbing}.dialog-handle{width:56px;height:5px;border-radius:999px;background:var(--border-strong)}@media (min-width: 720px){.dialog-handle-area{display:none}}.dialog-header{margin-bottom:var(--s-2);gap:var(--s-2)}.dialog-title{font-size:var(--fs-lg);font-weight:600;min-width:0;flex:1}.dialog-desc{font-size:var(--fs-sm);color:var(--text-muted);margin-bottom:var(--s-3)}.dialog-body{display:contents}.btn-close{width:48px;height:48px;flex:0 0 48px;border-radius:var(--r-pill);background:var(--surface);border:1px solid var(--border);color:var(--text-muted);display:inline-flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;transition:transform 80ms ease,background .12s ease,color .12s ease}.btn-close:hover{color:var(--text);background:var(--surface-strong)}.btn-close:active{transform:scale(.94)}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}@keyframes sheet-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes dialog-in{0%{transform:translate(-50%,-46%);opacity:0}to{transform:translate(-50%,calc(-50% + var(--sheet-y, 0px)));opacity:1}}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:var(--fs-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--text-subtle);font-weight:600}.input,.select-trigger{width:100%;padding:12px 14px;border-radius:var(--r-2);border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:16px;line-height:1.4;outline:none;transition:border-color .12s ease,background .12s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none}.input:focus,.select-trigger:focus{border-color:var(--border-strong);background:var(--surface-strong)}.segment{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-2);padding:4px;gap:2px}.segment button{flex:1;padding:8px 10px;border-radius:8px;font-size:var(--fs-sm);font-weight:600;color:var(--text-muted)}.segment button[aria-pressed=true],.segment button[data-state=active]{background:var(--surface-strong);color:var(--text)}.select-content{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-2);padding:6px;box-shadow:var(--shadow-2);z-index:70;min-width:var(--radix-select-trigger-width)}.select-item{padding:10px 12px;border-radius:8px;font-size:var(--fs-sm);display:flex;align-items:center;gap:8px;cursor:pointer;outline:none}.select-item[data-highlighted]{background:var(--surface-strong)}.select-item[data-state=checked]{color:var(--text)}.select-trigger{display:flex;align-items:center;justify-content:space-between;gap:var(--s-2)}.dot{width:8px;height:8px;border-radius:999px;background:var(--cat-color, var(--text-muted));flex:0 0 8px}.entry-list{display:flex;flex-direction:column;gap:2px}.entry-row{display:flex;justify-content:space-between;padding:10px 12px;border-radius:var(--r-2);background:var(--surface);font-variant-numeric:tabular-nums}.entry-row .when{color:var(--text-muted);font-size:var(--fs-sm)}
