@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;500;600;700;800;900&display=swap";
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--spacing:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--shadow-sm:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.absolute{position:absolute}.start{inset-inline-start:var(--spacing)}.flex{display:flex}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}}:root{--color-bg:#f4f4f9;--color-surface:#fff;--color-surface-2:#f0f0f7;--color-border:#e2e2ef;--color-border-muted:#ebebf5;--color-expense:#dc2626;--color-expense-dim:#fef2f2;--color-expense-glow:#dc262626;--color-income:#16a34a;--color-income-dim:#f0fdf4;--color-income-glow:#16a34a26;--color-text:#1a1a2e;--color-text-muted:#7070a0;--color-accent:#7c6afb;--color-accent-dim:#ede9fe;--shadow-sm:0 1px 4px #0000000f;--shadow-md:0 4px 16px #00000014;--shadow-lg:0 8px 32px #0000001a;--radius-sm:8px;--radius-md:16px;--radius-lg:24px;--radius-xl:32px;--radius-full:9999px}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,system-ui,sans-serif}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.app-shell{flex-direction:column;max-width:480px;min-height:100vh;margin:0 auto;padding:0 0 72px;display:flex}.type-radio-btn{border-radius:var(--radius-md);border:1px solid var(--color-border);letter-spacing:.04em;cursor:pointer;width:100%;margin-bottom:8px;padding:18px;font-family:Outfit,sans-serif;font-size:1rem;font-weight:700;transition:all .25s cubic-bezier(.34,1.56,.64,1)}.type-radio-btn.expense{background:var(--color-expense-dim);color:var(--color-expense);border-color:var(--color-expense)}.type-radio-btn.income{background:var(--color-income-dim);color:var(--color-income);border-color:var(--color-income)}.type-radio-btn:active{transform:scale(.98)}.mic-btn{border-radius:var(--radius-lg);border:2px dashed var(--color-border);background:var(--color-surface);width:100%;color:var(--color-text-muted);cursor:pointer;box-shadow:var(--shadow-sm);justify-content:center;align-items:center;gap:12px;padding:28px 20px;font-family:inherit;font-size:1rem;font-weight:500;transition:all .25s;display:flex}.mic-btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-dim)}.mic-btn.recording{border-color:var(--color-expense);background:var(--color-expense-dim);color:var(--color-expense);border-style:solid;animation:1.5s ease-in-out infinite pulse-border}@keyframes pulse-border{0%,to{box-shadow:0 0 0 0 var(--color-expense-glow)}50%{box-shadow:0 0 0 6px #0000}}.mic-icon{font-size:1.8rem;transition:transform .3s}.mic-btn.recording .mic-icon{animation:1s ease-in-out infinite mic-pulse}@keyframes mic-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.12)}}.transcript-bubble{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);align-items:center;gap:8px;padding:10px 14px;font-size:.85rem;display:flex}.transcript-bubble .t-dot{background:var(--color-accent);border-radius:50%;flex-shrink:0;width:6px;height:6px}.form-label{letter-spacing:.07em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:6px;font-size:.72rem;font-weight:600}.form-input{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text);box-shadow:var(--shadow-sm);outline:none;padding:14px 16px;font-family:inherit;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-input::placeholder{color:var(--color-text-muted)}.form-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-dim)}.form-input.amount-input{text-align:center;letter-spacing:-.02em;padding:20px 56px 20px 48px;font-family:Outfit,sans-serif;font-size:2.8rem;font-weight:800}.amount-wrapper{position:relative}.currency-symbol{color:var(--color-text-muted);pointer-events:none;font-family:Outfit,sans-serif;font-size:2rem;font-weight:700;position:absolute;top:50%;left:18px;transform:translateY(-50%)}.category-grid{grid-template-columns:repeat(4,1fr);gap:7px;display:grid}.category-chip{border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;text-align:center;box-shadow:var(--shadow-sm);border-radius:10px;flex-direction:column;align-items:center;gap:3px;padding:9px 6px;font-size:.72rem;font-weight:500;transition:all .15s;display:flex}.category-chip .cat-icon{font-size:1.1rem}.category-chip:hover{border-color:var(--color-accent);color:var(--color-text)}.category-chip.active{border-color:var(--color-accent);background:var(--color-accent-dim);color:var(--color-accent)}.submit-btn{border-radius:var(--radius-md);letter-spacing:.02em;cursor:pointer;border:none;width:100%;padding:18px;font-family:Outfit,sans-serif;font-size:1rem;font-weight:700;transition:all .25s cubic-bezier(.34,1.56,.64,1)}.submit-btn.expense-submit{background:var(--color-expense);color:#fff;box-shadow:0 4px 16px var(--color-expense-glow)}.submit-btn.income-submit{background:var(--color-income);color:#fff;box-shadow:0 4px 16px var(--color-income-glow)}.submit-btn:hover{filter:brightness(1.05);transform:translateY(-2px)}.submit-btn:active{transform:translateY(0)}.submit-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.toast{background:var(--color-text);border-radius:var(--radius-full);color:#fff;box-shadow:var(--shadow-lg);z-index:100;opacity:0;white-space:nowrap;padding:11px 22px;font-size:.85rem;font-weight:500;transition:all .35s cubic-bezier(.34,1.56,.64,1);position:fixed;bottom:86px;left:50%;transform:translate(-50%)translateY(16px)}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.toast.success{background:var(--color-income)}.toast.error{background:var(--color-expense)}.bottom-nav{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid var(--color-border);z-index:50;background:#ffffffeb;width:100%;max-width:480px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-btn{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:3px;padding:12px 8px;font-family:Inter,sans-serif;font-size:.68rem;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-btn .nav-icon{font-size:1.25rem;transition:transform .2s}.nav-btn.active{color:var(--color-accent)}.nav-btn.active .nav-icon{transform:scale(1.1)}.nav-btn:hover{color:var(--color-text)}.page-content{flex-direction:column;flex:1;padding:20px 16px 0;display:flex}.month-group{margin-bottom:20px}.month-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;margin-bottom:8px;padding:6px 0;display:flex}.month-title{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);font-size:.72rem;font-weight:700}.month-balance{font-family:Outfit,sans-serif;font-size:.85rem;font-weight:700}.tx-item{border-bottom:1px solid var(--color-border-muted);align-items:center;gap:12px;padding:13px 0;display:flex}.tx-item:last-child{border-bottom:none}.tx-icon{border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1rem;display:flex}.tx-icon.expense{background:var(--color-expense-dim)}.tx-icon.income{background:var(--color-income-dim)}.tx-info{flex:1;min-width:0}.tx-desc{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:500;overflow:hidden}.tx-meta{color:var(--color-text-muted);margin-top:2px;font-size:.72rem}.tx-amount{flex-shrink:0;font-family:Outfit,sans-serif;font-size:1rem;font-weight:700}.tx-amount.expense{color:var(--color-expense)}.tx-amount.income{color:var(--color-income)}.summary-row{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px;display:grid}.summary-card{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);padding:16px}.summary-card-label{letter-spacing:.07em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:6px;font-size:.68rem;font-weight:600}.summary-card-amount{letter-spacing:-.02em;font-family:Outfit,sans-serif;font-size:1.5rem;font-weight:800}.balance-positive{color:var(--color-income)}.balance-negative{color:var(--color-expense)}.divider{color:var(--color-text-muted);align-items:center;gap:10px;font-size:.72rem;font-weight:500;display:flex}.divider:before,.divider:after{content:"";background:var(--color-border);flex:1;height:1px}.spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}@supports (padding-bottom:env(safe-area-inset-bottom)){.bottom-nav{padding-bottom:env(safe-area-inset-bottom)}.app-shell{padding-bottom:calc(72px + env(safe-area-inset-bottom))}}@media (min-width:480px){.app-shell{border-left:1px solid var(--color-border);border-right:1px solid var(--color-border)}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}
