@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&family=DM+Serif+Display&display=swap";:root{--color-primary: #7C8B6F;--color-primary-light: #EFF2EC;--color-accent: #C4836A;--color-background: #FAF8F3;--color-surface: #FFFFFF;--color-text: #2C2418;--color-text-secondary: #8E8578;--color-muted: #B5ADA4;--color-border: #E8E4DD;--color-danger: #D14343;--color-danger-light: #FEF2F2;--color-success: #4CAF50;--color-input-bg: #F5F2EC;--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 20px;--space-2xl: 24px;--space-3xl: 32px;--space-4xl: 40px;--space-5xl: 64px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-pill: 9999px;--text-xs: 11px;--text-sm: 13px;--text-base: 15px;--text-md: 17px;--text-lg: 20px;--text-xl: 24px;--text-2xl: 28px;--text-3xl: 32px;--text-4xl: 40px;--font-heading: "DM Serif Display", Georgia, serif;--font-body: "DM Sans", system-ui, -apple-system, sans-serif;--shadow-sm: 0 1px 3px rgba(44, 36, 24, .06);--shadow-md: 0 2px 8px rgba(44, 36, 24, .08);--shadow-lg: 0 4px 16px rgba(44, 36, 24, .1);--tab-bar-height: 64px;--safe-area-bottom: env(safe-area-inset-bottom, 0px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-body);font-size:var(--text-base);line-height:1.5;color:var(--color-text);background-color:var(--color-background);min-height:100vh;min-height:100dvh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior-y:none}#root{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:400;line-height:1.2;color:var(--color-text)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}p{margin:0;line-height:1.6}a{color:var(--color-primary);text-decoration:none}ul,ol{list-style:none}img,svg{display:block;max-width:100%}input,textarea,select{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text);border:1.5px solid var(--color-border);background-color:var(--color-input-bg);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);width:100%;outline:none;transition:border-color .2s ease,box-shadow .2s ease;-webkit-appearance:none;appearance:none}input:focus,textarea:focus,select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}input::placeholder,textarea::placeholder{color:var(--color-muted)}button{font-family:var(--font-body);font-size:var(--text-base);cursor:pointer;border:none;background:none;color:inherit;line-height:1;-webkit-appearance:none;appearance:none}button:disabled{opacity:.5;cursor:not-allowed}.app-container{width:100%;max-width:480px;margin:0 auto;min-height:100vh;min-height:100dvh;position:relative}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.gap-xl{gap:var(--space-xl)}.gap-2xl{gap:var(--space-2xl)}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-md{font-size:var(--text-md)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.text-4xl{font-size:var(--text-4xl)}.font-heading{font-family:var(--font-heading)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-muted)}.text-danger{color:var(--color-danger)}.text-success{color:var(--color-success)}.text-accent{color:var(--color-accent)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.p-sm{padding:var(--space-sm)}.p-md{padding:var(--space-md)}.p-lg{padding:var(--space-lg)}.p-xl{padding:var(--space-xl)}.p-2xl{padding:var(--space-2xl)}.px-lg{padding-left:var(--space-lg);padding-right:var(--space-lg)}.px-xl{padding-left:var(--space-xl);padding-right:var(--space-xl)}.py-sm{padding-top:var(--space-sm);padding-bottom:var(--space-sm)}.py-md{padding-top:var(--space-md);padding-bottom:var(--space-md)}.py-lg{padding-top:var(--space-lg);padding-bottom:var(--space-lg)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mt-xl{margin-top:var(--space-xl)}.mt-2xl{margin-top:var(--space-2xl)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.mb-xl{margin-bottom:var(--space-xl)}.mb-2xl{margin-bottom:var(--space-2xl)}.w-full{width:100%}.h-full{height:100%}.relative{position:relative}.absolute{position:absolute}.overflow-hidden{overflow:hidden}.overflow-auto{overflow-y:auto}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.card{background-color:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.card-flat{background-color:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-xl);border:1px solid var(--color-border)}.card-elevated{background-color:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-md)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);font-size:var(--text-base);font-weight:500;border-radius:var(--radius-md);border:none;cursor:pointer;transition:background-color .2s ease,transform .1s ease,box-shadow .2s ease;white-space:nowrap;line-height:1.4;min-height:44px;-webkit-user-select:none;user-select:none}.btn:active:not(:disabled){transform:scale(.97)}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:#6e7d62}.btn-primary:active:not(:disabled){background-color:#616f56}.btn-outline{background-color:transparent;color:var(--color-primary);border:1.5px solid var(--color-primary)}.btn-outline:hover:not(:disabled){background-color:var(--color-primary-light)}.btn-danger{background-color:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background-color:#b93a3a}.btn-ghost{background-color:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background-color:var(--color-primary-light);color:var(--color-text)}.btn-accent{background-color:var(--color-accent);color:#fff}.btn-accent:hover:not(:disabled){background-color:#b6755d}.btn-sm{padding:var(--space-sm) var(--space-md);font-size:var(--text-sm);min-height:34px;border-radius:var(--radius-sm)}.btn-lg{padding:var(--space-lg) var(--space-2xl);font-size:var(--text-md);min-height:52px;border-radius:var(--radius-lg)}.btn-full{width:100%}.btn-icon{padding:var(--space-sm);min-height:40px;min-width:40px;border-radius:var(--radius-md)}.input{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text);border:1.5px solid var(--color-border);background-color:var(--color-input-bg);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);width:100%;outline:none;transition:border-color .2s ease,box-shadow .2s ease;min-height:48px}.input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.input::placeholder{color:var(--color-muted)}.input-error{border-color:var(--color-danger)}.input-error:focus{box-shadow:0 0 0 3px var(--color-danger-light)}.input-label{display:block;font-size:var(--text-sm);font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.input-helper{font-size:var(--text-xs);color:var(--color-text-secondary);margin-top:var(--space-xs)}.input-error-text{font-size:var(--text-xs);color:var(--color-danger);margin-top:var(--space-xs)}.badge{display:inline-flex;align-items:center;justify-content:center;padding:2px var(--space-sm);font-size:var(--text-xs);font-weight:600;border-radius:var(--radius-pill);white-space:nowrap;line-height:1.4}.badge-primary{background-color:var(--color-primary-light);color:var(--color-primary)}.badge-accent{background-color:#f9ede8;color:var(--color-accent)}.badge-danger{background-color:var(--color-danger-light);color:var(--color-danger)}.badge-success{background-color:#e8f5e9;color:var(--color-success)}.badge-muted{background-color:var(--color-input-bg);color:var(--color-text-secondary)}.chip{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-lg);font-size:var(--text-sm);font-weight:500;border-radius:var(--radius-pill);border:1.5px solid var(--color-border);background-color:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease;white-space:nowrap;-webkit-user-select:none;user-select:none}.chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.chip-active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.chip-active:hover{background-color:#6e7d62;border-color:#6e7d62;color:#fff}.divider{width:100%;height:1px;background-color:var(--color-border);border:none;margin:var(--space-lg) 0}.divider-thin{margin:var(--space-sm) 0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-4xl) var(--space-2xl);gap:var(--space-md)}.empty-state-icon{font-size:48px;line-height:1;margin-bottom:var(--space-sm);opacity:.5}.empty-state-title{font-family:var(--font-heading);font-size:var(--text-lg);color:var(--color-text)}.empty-state-message{font-size:var(--text-sm);color:var(--color-text-secondary);max-width:260px;line-height:1.5}.loading-spinner{display:inline-block;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}.loading-spinner-sm{width:20px;height:20px;border-width:2px}.loading-spinner-md{width:32px;height:32px;border-width:3px}.loading-spinner-lg{width:48px;height:48px;border-width:3px}.loading-spinner-container{display:flex;align-items:center;justify-content:center;padding:var(--space-4xl)}@keyframes spin{to{transform:rotate(360deg)}}.toast-container{position:fixed;top:var(--space-lg);left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:var(--space-sm);width:calc(100% - var(--space-3xl));max-width:440px;pointer-events:none}.toast{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);font-size:var(--text-sm);font-weight:500;pointer-events:auto;animation:toast-in .3s ease}.toast-exit{animation:toast-out .25s ease forwards}.toast-success{background-color:var(--color-success);color:#fff}.toast-error{background-color:var(--color-danger);color:#fff}.toast-info{background-color:var(--color-primary);color:#fff}.toast-message{flex:1}.toast-close{background:none;border:none;color:inherit;cursor:pointer;padding:var(--space-xs);opacity:.8;font-size:var(--text-md);line-height:1}.toast-close:hover{opacity:1}@keyframes toast-in{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes toast-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-12px)}}.app-layout{width:100%;max-width:480px;margin:0 auto;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;position:relative;background-color:var(--color-background)}@media(min-width:481px){.app-layout{box-shadow:-1px 0 0 var(--color-border),1px 0 0 var(--color-border)}}.app-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:calc(var(--tab-bar-height) + var(--safe-area-bottom))}.tab-bar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;height:calc(var(--tab-bar-height) + var(--safe-area-bottom));padding-bottom:var(--safe-area-bottom);background-color:var(--color-surface);border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-around;z-index:100}.tab-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;flex:1;padding:var(--space-sm) 0;color:var(--color-muted);text-decoration:none;transition:color .2s ease;-webkit-tap-highlight-color:transparent}.tab-item:hover{color:var(--color-text-secondary)}.tab-item-active{color:var(--color-primary)}.tab-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px}.tab-label{font-size:var(--text-xs);font-weight:500;line-height:1}.auth-layout{width:100%;max-width:480px;margin:0 auto;min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:var(--space-2xl);background-color:var(--color-background)}@media(min-width:481px){.auth-layout{box-shadow:-1px 0 0 var(--color-border),1px 0 0 var(--color-border)}}.auth-container{width:100%;display:flex;flex-direction:column;gap:var(--space-2xl)}.auth-page{width:100%;display:flex;flex-direction:column;align-items:center;gap:var(--space-3xl)}.auth-header{text-align:center;display:flex;flex-direction:column;gap:var(--space-sm)}.auth-header h1{font-family:var(--font-heading);font-size:var(--text-3xl);color:var(--color-text)}.auth-header p{font-size:var(--text-base);color:var(--color-text-secondary);line-height:1.5}.auth-form{width:100%;display:flex;flex-direction:column;gap:var(--space-xl)}.auth-field{display:flex;flex-direction:column;gap:var(--space-xs)}.auth-field label{font-size:var(--text-sm);font-weight:500;color:var(--color-text-secondary)}.auth-field input{min-height:48px}.auth-submit{margin-top:var(--space-sm)}.auth-submit .btn{position:relative}.auth-submit .btn .btn-spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.auth-footer{text-align:center;display:flex;flex-direction:column;gap:var(--space-md);font-size:var(--text-sm);color:var(--color-text-secondary)}.auth-footer a{color:var(--color-primary);font-weight:500;text-decoration:none;transition:color .2s ease}.auth-footer a:hover{color:#6e7d62;text-decoration:underline}.auth-link-row{display:flex;align-items:center;justify-content:center;gap:var(--space-xs)}.auth-forgot-link{text-align:right;margin-top:calc(-1 * var(--space-md))}.auth-forgot-link a{font-size:var(--text-sm);color:var(--color-text-secondary);text-decoration:none;transition:color .2s ease}.auth-forgot-link a:hover{color:var(--color-primary)}.auth-success{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);text-align:center;padding:var(--space-2xl);background-color:#e8f5e9;border-radius:var(--radius-lg)}.auth-success-icon{font-size:48px;line-height:1}.auth-success h2{font-family:var(--font-heading);font-size:var(--text-xl);color:var(--color-text)}.auth-success p{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.5;max-width:280px}.auth-divider{display:flex;align-items:center;gap:var(--space-lg);color:var(--color-muted);font-size:var(--text-sm)}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background-color:var(--color-border)}.transactions-page{display:flex;flex-direction:column;height:100%}.transactions-header{padding:var(--space-lg) var(--space-2xl) var(--space-sm);display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.transactions-title{font-family:var(--font-heading);font-size:var(--text-xl);color:var(--color-text)}.transactions-header-actions{display:flex;align-items:center;gap:var(--space-sm)}.transactions-search{padding:var(--space-xs) var(--space-2xl) var(--space-xs)}.transactions-search-bar{display:flex;align-items:center;gap:var(--space-md);background-color:var(--color-input-bg);border:1.5px solid var(--color-border);border-radius:var(--radius-pill);padding:0 var(--space-xl);height:46px;transition:border-color .2s ease,background-color .2s ease}.transactions-search-bar:focus-within{border-color:var(--color-primary);background-color:var(--color-primary-light)}.transactions-search-icon{color:var(--color-muted);font-size:var(--text-md);flex-shrink:0}.transactions-search-bar:focus-within .transactions-search-icon{color:var(--color-primary)}.transactions-search-input{flex:1;border:none;background:none;padding:var(--space-md) 0;font-size:var(--text-base);color:var(--color-text);outline:none;min-width:0}.transactions-search-input::placeholder{color:var(--color-muted)}.transactions-search-clear{background:none;border:none;color:var(--color-muted);cursor:pointer;padding:var(--space-xs);font-size:var(--text-md);display:flex;align-items:center}.transactions-chips{display:flex;gap:var(--space-sm);padding:var(--space-md) var(--space-2xl);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.transactions-chips::-webkit-scrollbar{display:none}.transactions-list{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 var(--space-2xl) var(--space-5xl)}.transactions-date-group{margin-bottom:var(--space-xl)}.transactions-date-label{font-size:var(--text-sm);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;padding:var(--space-sm) 0 var(--space-sm);position:sticky;top:0;background-color:var(--color-background);z-index:1}.transactions-date-card{border-radius:var(--radius-lg);padding:var(--space-xs) 0}.transactions-fab{position:fixed;bottom:calc(var(--tab-bar-height) + var(--safe-area-bottom) + 16px);right:calc(50% - 220px);width:56px;height:56px;border-radius:var(--radius-pill);background-color:var(--color-primary);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:var(--shadow-lg);transition:opacity .2s ease,transform .1s ease;z-index:50}.transactions-fab:hover{opacity:.9}.transactions-fab:active{transform:scale(.93)}@media(max-width:480px){.transactions-fab{right:var(--space-xl)}}.transaction-row{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);cursor:pointer;transition:background-color .15s ease;border-radius:var(--radius-md)}.transaction-row:hover{background-color:var(--color-input-bg)}.transaction-row-dot{width:10px;height:10px;border-radius:var(--radius-pill);flex-shrink:0}.transaction-row-info{flex:1;min-width:0}.transaction-row-merchant{font-size:var(--text-base);font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.transaction-row-notes{font-size:var(--text-xs);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.transaction-row-right{text-align:right;flex-shrink:0}.transaction-row-amount{font-size:var(--text-base);font-weight:600;color:var(--color-text)}.transaction-row-date{font-size:var(--text-xs);color:var(--color-text-secondary);margin-top:1px}.budgets-page{padding:var(--space-2xl);padding-bottom:var(--space-5xl);display:flex;flex-direction:column;gap:var(--space-xl)}.budgets-summary{text-align:center;padding:var(--space-2xl) var(--space-lg)}.budgets-summary-currency{font-size:var(--text-xs);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:var(--space-lg)}.budgets-summary-row{display:flex;justify-content:space-around;gap:var(--space-md)}.budgets-summary-item{flex:1;text-align:center}.budgets-summary-value{font-family:var(--font-heading);font-size:var(--text-2xl);color:var(--color-text)}.budgets-summary-label{font-size:var(--text-xs);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-top:var(--space-xs)}.budgets-summary-divider{width:1px;background-color:var(--color-border);align-self:stretch}.budgets-overall-progress{margin-top:var(--space-lg);padding:0 var(--space-lg)}.budgets-overall-bar-track{height:8px;border-radius:var(--radius-pill);background-color:var(--color-input-bg);overflow:hidden}.budgets-overall-bar-fill{height:100%;border-radius:var(--radius-pill);transition:width .4s ease}.budgets-overall-label{display:flex;justify-content:space-between;margin-top:var(--space-xs);font-size:var(--text-xs);color:var(--color-text-secondary)}.budgets-list{display:flex;flex-direction:column;gap:var(--space-md)}.budget-card{padding:var(--space-lg);cursor:pointer;transition:transform .1s ease,box-shadow .2s ease}.budget-card:hover{box-shadow:var(--shadow-md)}.budget-card:active{transform:scale(.99)}.budget-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}.budget-card-left{display:flex;align-items:center;gap:var(--space-md);flex:1;min-width:0}.budget-card-dot{width:12px;height:12px;border-radius:var(--radius-pill);flex-shrink:0}.budget-card-info{flex:1;min-width:0}.budget-card-name{font-size:var(--text-base);font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.budget-card-amount{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:1px}.budget-card-right{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.budget-card-percentage{font-size:var(--text-base);font-weight:700}.budget-card-shared{font-size:var(--text-sm);color:var(--color-primary);opacity:.7}.budget-card-over{font-size:var(--text-xs);font-weight:700;color:var(--color-danger);background-color:var(--color-danger-light);padding:2px var(--space-sm);border-radius:var(--radius-pill)}.budget-card-remaining{font-size:var(--text-xs);font-weight:500;color:var(--color-text-secondary)}.budget-progress-track{height:6px;border-radius:var(--radius-pill);background-color:var(--color-input-bg);overflow:hidden}.budget-progress-fill{height:100%;border-radius:var(--radius-pill);transition:width .4s ease}.budgets-footer{display:flex;flex-direction:column;gap:var(--space-md);margin-top:var(--space-lg)}.budgets-footer .btn{border-radius:var(--radius-pill);min-height:52px}.dashboard{padding:var(--space-2xl);padding-bottom:var(--space-5xl);display:flex;flex-direction:column;gap:var(--space-3xl)}.dashboard-greeting{font-size:var(--text-sm);color:var(--color-text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:1.5px}.dashboard-greeting-name{font-family:var(--font-heading);font-size:var(--text-xl);color:var(--color-text);margin-top:var(--space-xs)}.dashboard-summary{text-align:center;padding:var(--space-4xl) var(--space-xl);border-top:3px solid var(--color-primary)}.dashboard-summary-label{font-size:var(--text-sm);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:1.5px}.dashboard-summary-amount{font-family:var(--font-heading);font-size:var(--text-4xl);color:var(--color-text);letter-spacing:-1px;margin-top:var(--space-xs)}.dashboard-summary-row{display:flex;gap:var(--space-md);margin-top:var(--space-xl)}.dashboard-summary-badge{flex:1;text-align:center;padding:var(--space-md);border-radius:var(--radius-md)}.dashboard-summary-badge-label{font-size:var(--text-xs);font-weight:500;color:var(--color-text-secondary)}.dashboard-summary-badge-value{font-family:var(--font-heading);font-size:var(--text-md);margin-top:2px}.dashboard-quick-actions{display:flex;gap:var(--space-md)}.dashboard-quick-action{flex:1;display:flex;flex-direction:column;align-items:center;padding:var(--space-xl) var(--space-md);border-radius:var(--radius-xl);border:none;cursor:pointer;transition:opacity .2s ease,transform .1s ease;box-shadow:var(--shadow-sm)}.dashboard-quick-action:hover{opacity:.85}.dashboard-quick-action:active{transform:scale(.97)}.dashboard-quick-action-icon{width:48px;height:48px;border-radius:var(--radius-pill);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-sm);font-size:22px}.dashboard-quick-action-label{font-size:var(--text-sm);font-weight:600}.dashboard-alerts{display:flex;flex-direction:column;gap:var(--space-sm)}.dashboard-alert{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background-color:var(--color-danger-light);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;color:var(--color-danger)}.dashboard-alert-icon{font-size:var(--text-md);flex-shrink:0}.dashboard-coach{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);background-color:var(--color-surface);border-radius:var(--radius-lg);cursor:pointer;transition:opacity .2s ease,transform .1s ease;box-shadow:var(--shadow-sm);border:none;width:100%;text-align:left}.dashboard-coach:hover{opacity:.92}.dashboard-coach:active{transform:scale(.98)}.dashboard-coach-icon{width:44px;height:44px;border-radius:50%;background-color:var(--color-primary-light);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.dashboard-coach-content{flex:1}.dashboard-coach-title{font-size:var(--text-base);font-weight:600;color:var(--color-text)}.dashboard-coach-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:2px}.dashboard-coach-arrow{color:var(--color-primary);font-size:var(--text-lg)}.dashboard-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.dashboard-section-title{font-family:var(--font-heading);font-size:var(--text-lg);color:var(--color-text)}.dashboard-see-all{font-size:var(--text-sm);font-weight:600;color:var(--color-primary);background:none;border:none;cursor:pointer;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-pill);background-color:var(--color-primary-light);transition:opacity .2s ease}.dashboard-see-all:hover{opacity:.8}.dashboard-transactions-card{padding:var(--space-xs) 0;border-radius:var(--radius-lg)}.dashboard-empty{text-align:center;padding:var(--space-4xl) var(--space-lg)}.dashboard-empty-icon{font-size:32px;opacity:.4;margin-bottom:var(--space-sm)}.dashboard-empty-text{font-size:var(--text-sm);color:var(--color-text-secondary)}.analytics-page{padding:var(--space-2xl);padding-bottom:calc(var(--tab-bar-height) + var(--space-5xl))}.analytics-header{text-align:center;margin-bottom:var(--space-3xl)}.analytics-header-title{font-family:var(--font-heading);font-size:var(--text-3xl);color:var(--color-text);letter-spacing:-.5px}.analytics-month-selector{display:flex;align-items:center;justify-content:center;gap:var(--space-lg);margin-top:var(--space-md)}.analytics-month-arrow{width:36px;height:36px;border-radius:var(--radius-pill);background-color:var(--color-input-bg);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--color-text);transition:opacity .15s}.analytics-month-arrow:hover:not(:disabled){opacity:.7}.analytics-month-arrow:disabled{opacity:.3}.analytics-month-label{font-weight:600;font-size:var(--text-md);color:var(--color-text);min-width:140px;text-align:center}.analytics-header-total{font-family:var(--font-heading);font-size:var(--text-2xl);color:var(--color-accent);margin-top:var(--space-sm)}.analytics-section{margin-bottom:var(--space-3xl)}.analytics-section-title{font-family:var(--font-heading);font-size:var(--text-lg);color:var(--color-text);margin-bottom:var(--space-lg)}.analytics-section-card{border-radius:var(--radius-xl);padding:var(--space-xl);background:var(--color-surface);box-shadow:var(--shadow-lg)}.analytics-treemap{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:var(--space-xl);min-height:200px;border-radius:var(--radius-md);overflow:hidden}.analytics-treemap-cell{display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--text-xs);font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.3);cursor:pointer;transition:opacity .15s,transform .15s;border-radius:4px;overflow:hidden;padding:4px;text-align:center;line-height:1.2}.analytics-treemap-cell:hover{opacity:.85;transform:scale(1.02)}.analytics-legend{display:flex;flex-direction:column;gap:var(--space-md)}.analytics-legend-item{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;transition:opacity .15s}.analytics-legend-item:hover{opacity:.7}.analytics-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.analytics-legend-name{font-weight:500;font-size:var(--text-sm);color:var(--color-text);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.analytics-legend-amount{font-weight:600;font-size:var(--text-sm);color:var(--color-text-secondary)}.analytics-legend-chevron{font-size:var(--text-sm);color:var(--color-muted)}.analytics-heatmap{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:var(--space-sm)}.analytics-heatmap-grid{display:flex;gap:3px}.analytics-heatmap-column{display:flex;flex-direction:column;gap:3px}.analytics-heatmap-cell{width:14px;height:14px;border-radius:3px;transition:transform .15s}.analytics-heatmap-cell:hover{transform:scale(1.3)}.analytics-heatmap-labels{display:flex;gap:3px;margin-bottom:var(--space-xs)}.analytics-heatmap-month-labels{display:flex;gap:3px;margin-top:var(--space-xs);padding-left:0}.analytics-heatmap-month-label{font-size:10px;color:var(--color-muted)}.analytics-merchant-list{display:flex;flex-direction:column;gap:var(--space-md)}.analytics-merchant-row{display:flex;align-items:center;gap:var(--space-md);cursor:pointer;transition:opacity .15s}.analytics-merchant-row:hover{opacity:.7}.analytics-merchant-rank{font-weight:700;font-size:var(--text-sm);color:var(--color-muted);width:24px;text-align:center;flex-shrink:0}.analytics-merchant-icon{width:38px;height:38px;border-radius:var(--radius-pill);display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:var(--text-md);flex-shrink:0}.analytics-merchant-info{flex:1;min-width:0}.analytics-merchant-name{font-weight:600;font-size:var(--text-sm);color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.analytics-merchant-count{font-size:var(--text-xs);color:var(--color-text-secondary)}.analytics-merchant-amount{font-weight:600;font-size:var(--text-sm);color:var(--color-text);text-align:right;flex-shrink:0}.analytics-merchant-bar-wrap{flex:1;height:6px;background:var(--color-border);border-radius:var(--radius-pill);overflow:hidden}.analytics-merchant-bar{height:100%;border-radius:var(--radius-pill);transition:width .3s ease}.analytics-empty{text-align:center;padding:var(--space-3xl) var(--space-xl);color:var(--color-muted)}.analytics-empty-icon{font-size:32px;margin-bottom:var(--space-md)}.analytics-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-5xl) 0;gap:var(--space-md)}.analytics-loading-text{font-weight:500;font-size:var(--text-sm);color:var(--color-text-secondary)}.settings-page{padding:var(--space-2xl);padding-bottom:var(--space-5xl)}.settings-section{margin-bottom:var(--space-3xl)}.settings-section-title{font-family:var(--font-heading);font-size:var(--text-md);color:var(--color-text);letter-spacing:.3px;margin-bottom:var(--space-md);padding-left:var(--space-xs)}.settings-card{background-color:var(--color-surface);border-radius:var(--radius-lg);padding:0 var(--space-lg);box-shadow:var(--shadow-sm)}.settings-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg) 0;min-height:52px}.settings-row-clickable{cursor:pointer;transition:opacity .15s ease}.settings-row-clickable:hover{opacity:.7}.settings-row-left{display:flex;align-items:center;gap:var(--space-md);flex:1;min-width:0}.settings-row-icon{width:24px;font-size:var(--text-lg);color:var(--color-muted);text-align:center;flex-shrink:0}.settings-row-label{font-size:var(--text-base);font-weight:500;color:var(--color-text)}.settings-row-right{display:flex;align-items:center;gap:var(--space-xs)}.settings-row-value{font-size:var(--text-base);color:var(--color-text-secondary);flex-shrink:1;text-align:right;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.settings-row-chevron{color:var(--color-muted);font-size:var(--text-md)}.settings-divider{height:1px;background-color:var(--color-border)}.settings-sign-out{display:flex;align-items:center;justify-content:center;gap:var(--space-md);width:100%;padding:var(--space-lg);border-radius:var(--radius-pill);background-color:var(--color-danger-light);border:none;cursor:pointer;margin-top:var(--space-lg);transition:opacity .2s ease,transform .1s ease}.settings-sign-out:hover{opacity:.85}.settings-sign-out:active{transform:scale(.98)}.settings-sign-out-icon{font-size:var(--text-lg);color:var(--color-danger)}.settings-sign-out-text{font-size:var(--text-base);font-weight:600;color:var(--color-danger)}.settings-confirm-overlay{position:fixed;inset:0;background-color:#2c241866;display:flex;align-items:center;justify-content:center;z-index:200;padding:var(--space-2xl);animation:settings-fade-in .2s ease}.settings-confirm-dialog{background-color:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-2xl);max-width:340px;width:100%;box-shadow:var(--shadow-lg)}.settings-confirm-title{font-family:var(--font-heading);font-size:var(--text-lg);color:var(--color-text);margin-bottom:var(--space-sm)}.settings-confirm-message{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.5;margin-bottom:var(--space-xl)}.settings-confirm-actions{display:flex;gap:var(--space-md)}.settings-confirm-actions .btn{flex:1}@keyframes settings-fade-in{0%{opacity:0}to{opacity:1}}.add-expense-page{min-height:100vh;min-height:100dvh;background-color:var(--color-background);display:flex;flex-direction:column;max-width:480px;margin:0 auto;width:100%}.add-expense-topbar{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg) var(--space-xl);position:sticky;top:0;background-color:var(--color-background);z-index:10}.add-expense-back{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);background:none;border:none;cursor:pointer;color:var(--color-text);font-size:var(--text-xl);transition:background-color .2s ease}.add-expense-back:hover{background-color:var(--color-primary-light)}.add-expense-topbar h1{font-family:var(--font-heading);font-size:var(--text-xl);flex:1}.add-expense-body{flex:1;padding:var(--space-lg) var(--space-xl);display:flex;flex-direction:column;gap:var(--space-2xl);padding-bottom:var(--space-4xl)}.add-expense-amount-wrapper{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-2xl) 0}.add-expense-amount-label{font-size:var(--text-sm);font-weight:500;color:var(--color-text-secondary)}.add-expense-amount-input-row{display:flex;align-items:baseline;justify-content:center;gap:var(--space-xs)}.add-expense-currency-symbol{font-family:var(--font-heading);font-size:var(--text-3xl);color:var(--color-muted)}.add-expense-amount-input{font-family:var(--font-heading);font-size:var(--text-4xl);text-align:center;border:none;background:transparent;color:var(--color-text);width:200px;padding:0;min-height:auto;outline:none}.add-expense-amount-input:focus{border:none;box-shadow:none}.add-expense-amount-input::placeholder{color:var(--color-muted)}.add-expense-field{display:flex;flex-direction:column;gap:var(--space-xs)}.add-expense-field-label{font-size:var(--text-sm);font-weight:500;color:var(--color-text-secondary)}.add-expense-merchant-wrapper{position:relative}.add-expense-suggestions{position:absolute;top:100%;left:0;right:0;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:20;max-height:200px;overflow-y:auto;margin-top:var(--space-xs)}.add-expense-suggestion{padding:var(--space-md) var(--space-lg);cursor:pointer;font-size:var(--text-base);color:var(--color-text);transition:background-color .15s ease}.add-expense-suggestion:hover{background-color:var(--color-primary-light)}.add-expense-suggestion:not(:last-child){border-bottom:1px solid var(--color-border)}.add-expense-category-grid{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.add-expense-category-chip{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-lg);font-size:var(--text-sm);font-weight:500;border-radius:var(--radius-pill);border:1.5px solid var(--color-border);background-color:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease;white-space:nowrap;-webkit-user-select:none;user-select:none}.add-expense-category-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.add-expense-category-chip.selected{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.add-expense-category-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.add-expense-submit{margin-top:auto;padding-top:var(--space-lg)}.edit-budget-page{min-height:100vh;min-height:100dvh;background-color:var(--color-background);display:flex;flex-direction:column;max-width:480px;margin:0 auto;width:100%}.edit-budget-topbar{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg) var(--space-xl);position:sticky;top:0;background-color:var(--color-background);z-index:10}.edit-budget-back{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);background:none;border:none;cursor:pointer;color:var(--color-text);font-size:var(--text-xl);transition:background-color .2s ease}.edit-budget-back:hover{background-color:var(--color-primary-light)}.edit-budget-topbar h1{font-family:var(--font-heading);font-size:var(--text-xl);flex:1}.edit-budget-body{flex:1;padding:var(--space-lg) var(--space-xl);display:flex;flex-direction:column;gap:var(--space-2xl);padding-bottom:var(--space-4xl)}.edit-budget-field{display:flex;flex-direction:column;gap:var(--space-sm)}.edit-budget-field-label{font-size:var(--text-sm);font-weight:500;color:var(--color-text-secondary)}.edit-budget-category-grid{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.edit-budget-category-chip{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-lg);font-size:var(--text-sm);font-weight:500;border-radius:var(--radius-pill);border:1.5px solid var(--color-border);background-color:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease;white-space:nowrap;-webkit-user-select:none;user-select:none}.edit-budget-category-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.edit-budget-category-chip.selected{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.edit-budget-category-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.edit-budget-period-chips{display:flex;gap:var(--space-sm)}.edit-budget-period-chip{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--space-md) var(--space-lg);font-size:var(--text-sm);font-weight:500;border-radius:var(--radius-pill);border:1.5px solid var(--color-border);background-color:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.edit-budget-period-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.edit-budget-period-chip.selected{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.edit-budget-amount-row{display:flex;align-items:center;gap:var(--space-sm)}.edit-budget-currency{font-size:var(--text-lg);font-weight:600;color:var(--color-text-secondary);flex-shrink:0}.edit-budget-actions{display:flex;flex-direction:column;gap:var(--space-md);margin-top:auto;padding-top:var(--space-lg)}.edit-budget-confirm-overlay{position:fixed;inset:0;background-color:#2c241866;display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--space-xl)}.edit-budget-confirm-dialog{background-color:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-2xl);max-width:340px;width:100%;display:flex;flex-direction:column;gap:var(--space-lg);box-shadow:var(--shadow-lg)}.edit-budget-confirm-title{font-family:var(--font-heading);font-size:var(--text-lg);color:var(--color-text)}.edit-budget-confirm-message{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.5}.edit-budget-confirm-actions{display:flex;gap:var(--space-md);justify-content:flex-end}.shared-budget-page{min-height:100vh;min-height:100dvh;background-color:var(--color-background);display:flex;flex-direction:column;max-width:480px;margin:0 auto;width:100%}.shared-budget-topbar{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg) var(--space-xl);position:sticky;top:0;background-color:var(--color-background);z-index:10}.shared-budget-back{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);background:none;border:none;cursor:pointer;color:var(--color-text);font-size:var(--text-xl);transition:background-color .2s ease}.shared-budget-back:hover{background-color:var(--color-primary-light)}.shared-budget-topbar h1{font-family:var(--font-heading);font-size:var(--text-xl);flex:1}.shared-budget-body{flex:1;padding:var(--space-lg) var(--space-xl);display:flex;flex-direction:column;gap:var(--space-2xl);padding-bottom:var(--space-4xl)}.shared-budget-steps{display:flex;align-items:center;gap:var(--space-sm);justify-content:center;padding-bottom:var(--space-lg)}.shared-budget-step-dot{width:10px;height:10px;border-radius:50%;background-color:var(--color-border);transition:all .2s ease}.shared-budget-step-dot.active{background-color:var(--color-primary);width:28px;border-radius:var(--radius-pill)}.shared-budget-step-dot.completed{background-color:var(--color-primary)}.shared-budget-step-title{font-family:var(--font-heading);font-size:var(--text-lg);color:var(--color-text);margin-bottom:var(--space-sm)}.shared-budget-step-desc{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.5;margin-bottom:var(--space-xl)}.shared-budget-household-list{display:flex;flex-direction:column;gap:var(--space-md)}.shared-budget-household-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);background-color:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease}.shared-budget-household-item:hover{border-color:var(--color-primary)}.shared-budget-household-item.selected{border-color:var(--color-primary);background-color:var(--color-primary-light)}.shared-budget-household-name{font-weight:500;color:var(--color-text)}.shared-budget-household-chevron{color:var(--color-muted);font-size:var(--text-lg)}.shared-budget-create-row{display:flex;gap:var(--space-sm)}.shared-budget-create-row input{flex:1}.shared-budget-members-list{display:flex;flex-direction:column;gap:var(--space-sm)}.shared-budget-member-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background-color:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border)}.shared-budget-member-info{display:flex;flex-direction:column;gap:2px}.shared-budget-member-name{font-weight:500;font-size:var(--text-base);color:var(--color-text)}.shared-budget-member-email{font-size:var(--text-xs);color:var(--color-text-secondary)}.shared-budget-member-role{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.shared-budget-invite-row{display:flex;gap:var(--space-sm);margin-top:var(--space-md)}.shared-budget-invite-row input{flex:1}.shared-budget-invitations{display:flex;flex-direction:column;gap:var(--space-md);margin-top:var(--space-lg)}.shared-budget-invitations-title{font-size:var(--text-sm);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.shared-budget-invitation-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background-color:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border)}.shared-budget-invitation-name{font-weight:500;font-size:var(--text-base);color:var(--color-text)}.shared-budget-invitation-actions{display:flex;gap:var(--space-sm)}.shared-budget-field{display:flex;flex-direction:column;gap:var(--space-sm)}.shared-budget-field-label{font-size:var(--text-sm);font-weight:500;color:var(--color-text-secondary)}.shared-budget-category-grid{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.shared-budget-category-chip{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-lg);font-size:var(--text-sm);font-weight:500;border-radius:var(--radius-pill);border:1.5px solid var(--color-border);background-color:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease;white-space:nowrap;-webkit-user-select:none;user-select:none}.shared-budget-category-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.shared-budget-category-chip.selected{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.shared-budget-category-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.shared-budget-period-chips{display:flex;gap:var(--space-sm)}.shared-budget-period-chip{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--space-md) var(--space-lg);font-size:var(--text-sm);font-weight:500;border-radius:var(--radius-pill);border:1.5px solid var(--color-border);background-color:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.shared-budget-period-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.shared-budget-period-chip.selected{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.shared-budget-nav{display:flex;gap:var(--space-md);margin-top:auto;padding-top:var(--space-xl)}.shared-budget-nav .btn{flex:1}.ai-coach-page{min-height:100vh;min-height:100dvh;background-color:var(--color-background);display:flex;flex-direction:column;max-width:480px;margin:0 auto;width:100%}.ai-coach-topbar{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg) var(--space-xl);position:sticky;top:0;background-color:var(--color-background);z-index:10;border-bottom:1px solid var(--color-border)}.ai-coach-back{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);background:none;border:none;cursor:pointer;color:var(--color-text);font-size:var(--text-xl);transition:background-color .2s ease}.ai-coach-back:hover{background-color:var(--color-primary-light)}.ai-coach-topbar h1{font-family:var(--font-heading);font-size:var(--text-xl);flex:1}.ai-coach-messages{flex:1;overflow-y:auto;padding:var(--space-lg) var(--space-xl);display:flex;flex-direction:column;gap:var(--space-md)}.ai-coach-welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;text-align:center;padding:var(--space-4xl) var(--space-xl);gap:var(--space-xl)}.ai-coach-welcome-icon{font-size:56px;line-height:1}.ai-coach-welcome h2{font-family:var(--font-heading);font-size:var(--text-2xl);color:var(--color-text)}.ai-coach-welcome p{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.5;max-width:280px}.ai-coach-prompts{display:flex;flex-wrap:wrap;gap:var(--space-sm);justify-content:center;max-width:340px}.ai-coach-prompt-pill{padding:var(--space-sm) var(--space-lg);font-size:var(--text-sm);font-weight:500;border-radius:var(--radius-pill);border:1.5px solid var(--color-border);background-color:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease;white-space:nowrap}.ai-coach-prompt-pill:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:var(--color-primary-light)}.ai-coach-message{max-width:85%;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);font-size:var(--text-base);line-height:1.6;animation:ai-coach-fade-in .2s ease;word-wrap:break-word}.ai-coach-message-user{align-self:flex-end;background-color:var(--color-primary);color:#fff;border-bottom-right-radius:var(--radius-sm)}.ai-coach-message-assistant{align-self:flex-start;background-color:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);border-bottom-left-radius:var(--radius-sm)}@keyframes ai-coach-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.ai-coach-typing{display:flex;align-items:center;gap:5px;padding:var(--space-md) var(--space-lg);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);border-bottom-left-radius:var(--radius-sm);align-self:flex-start}.ai-coach-typing-dot{width:8px;height:8px;border-radius:50%;background-color:var(--color-muted);animation:ai-coach-bounce 1.4s ease-in-out infinite}.ai-coach-typing-dot:nth-child(2){animation-delay:.2s}.ai-coach-typing-dot:nth-child(3){animation-delay:.4s}@keyframes ai-coach-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}.ai-coach-input-bar{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);border-top:1px solid var(--color-border);background-color:var(--color-background);position:sticky;bottom:0}.ai-coach-input{flex:1;min-height:44px;border-radius:var(--radius-pill);padding:var(--space-md) var(--space-lg)}.ai-coach-send-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background-color:var(--color-primary);color:#fff;border:none;cursor:pointer;transition:background-color .2s ease,transform .1s ease;flex-shrink:0}.ai-coach-send-btn:hover:not(:disabled){background-color:#6e7d62}.ai-coach-send-btn:active:not(:disabled){transform:scale(.95)}.ai-coach-send-btn:disabled{opacity:.5;cursor:not-allowed}.ai-coach-send-btn svg{width:20px;height:20px}.currency-picker-page{min-height:100vh;min-height:100dvh;background-color:var(--color-background);display:flex;flex-direction:column;max-width:480px;margin:0 auto;width:100%}.currency-picker-topbar{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg) var(--space-xl);position:sticky;top:0;background-color:var(--color-background);z-index:10}.currency-picker-back{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);background:none;border:none;cursor:pointer;color:var(--color-text);font-size:var(--text-xl);transition:background-color .2s ease}.currency-picker-back:hover{background-color:var(--color-primary-light)}.currency-picker-topbar h1{font-family:var(--font-heading);font-size:var(--text-xl);flex:1}.currency-picker-search{padding:0 var(--space-xl) var(--space-lg)}.currency-picker-search input{border-radius:var(--radius-pill);padding:var(--space-md) var(--space-lg)}.currency-picker-list{flex:1;overflow-y:auto;padding:0 var(--space-xl)}.currency-picker-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);cursor:pointer;transition:background-color .15s ease;border-radius:var(--radius-md)}.currency-picker-item:hover{background-color:var(--color-primary-light)}.currency-picker-item:not(:last-child){border-bottom:1px solid var(--color-border)}.currency-picker-item-left{display:flex;align-items:center;gap:var(--space-md)}.currency-picker-item-symbol{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);background-color:var(--color-primary-light);font-weight:600;font-size:var(--text-base);color:var(--color-primary);flex-shrink:0}.currency-picker-item-info{display:flex;flex-direction:column;gap:2px}.currency-picker-item-name{font-weight:500;font-size:var(--text-base);color:var(--color-text)}.currency-picker-item-code{font-size:var(--text-xs);color:var(--color-text-secondary)}.currency-picker-item-check{color:var(--color-primary);font-size:var(--text-xl);font-weight:700}.currency-picker-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-4xl) var(--space-xl);gap:var(--space-md);text-align:center}.currency-picker-empty-text{font-size:var(--text-sm);color:var(--color-text-secondary)}.bills-page{padding:var(--space-2xl);padding-bottom:var(--space-5xl);min-height:100vh}.bills-topbar{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-2xl)}.bills-back{width:36px;height:36px;border-radius:var(--radius-pill);background:var(--color-input-bg);display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--color-text)}.bills-topbar h1{font-size:var(--text-xl);flex:1}.bills-detect-btn{width:36px;height:36px;border-radius:var(--radius-pill);background:var(--color-primary-light);display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--color-primary)}.bills-summary{border-radius:var(--radius-xl);padding:var(--space-xl);background:var(--color-surface);box-shadow:var(--shadow-lg);margin-bottom:var(--space-3xl)}.bills-summary-row{display:flex;align-items:center}.bills-summary-item{flex:1;text-align:center}.bills-summary-label{font-weight:500;font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-xs)}.bills-summary-value{font-family:var(--font-heading);font-size:var(--text-lg);color:var(--color-text)}.bills-summary-divider{width:1px;height:40px;background:var(--color-border)}.bills-section{margin-bottom:var(--space-3xl)}.bills-section-title{font-family:var(--font-heading);font-size:var(--text-lg);color:var(--color-text);margin-bottom:var(--space-lg)}.bills-card{border-radius:var(--radius-xl);padding:var(--space-lg);background:var(--color-surface);box-shadow:var(--shadow-lg)}.bills-separator{height:1px;background:var(--color-border);margin:var(--space-md) 0}.bill-row{display:flex;gap:var(--space-md)}.bill-merchant-icon{width:42px;height:42px;border-radius:var(--radius-pill);display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:var(--text-md);flex-shrink:0}.bill-info{flex:1;min-width:0}.bill-top-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xs)}.bill-merchant{font-weight:600;font-size:var(--text-base);color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;margin-right:var(--space-sm)}.bill-amount{font-family:var(--font-heading);font-size:var(--text-base);color:var(--color-text)}.bill-bottom-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.bill-meta{display:flex;gap:var(--space-xs)}.bill-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:600}.bill-due-date{font-weight:500;font-size:var(--text-xs)}.bill-actions{display:flex;align-items:center;justify-content:space-between}.bill-mark-paid{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-md);background:var(--color-primary-light);border-radius:var(--radius-pill);font-weight:600;font-size:var(--text-xs);color:var(--color-primary);transition:opacity .15s}.bill-mark-paid:hover{opacity:.7}.bill-delete{padding:var(--space-sm);color:var(--color-danger);font-size:16px;transition:opacity .15s}.bill-delete:hover{opacity:.7}.bills-detection-card{border-radius:var(--radius-xl);padding:var(--space-xl);background:var(--color-surface);border:1.5px solid var(--color-primary-light);margin-bottom:var(--space-3xl)}.bills-detection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.bills-detection-title{font-family:var(--font-heading);font-size:var(--text-md);color:var(--color-text)}.bills-detection-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-xl)}.bills-detection-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) 0;border-top:1px solid var(--color-border)}.bills-detection-info{flex:1;margin-right:var(--space-md)}.bills-detection-merchant{font-weight:600;font-size:var(--text-base);color:var(--color-text)}.bills-detection-meta{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:2px}.bills-detect-section{margin-top:var(--space-lg)}.tx-detail-page{padding:var(--space-2xl);padding-bottom:var(--space-5xl);min-height:100vh}.tx-detail-topbar{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-2xl)}.tx-detail-back{width:36px;height:36px;border-radius:var(--radius-pill);background:var(--color-input-bg);display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--color-text)}.tx-detail-topbar h1{font-size:var(--text-xl);flex:1}.tx-detail-edit-btn{width:36px;height:36px;border-radius:var(--radius-pill);background:var(--color-input-bg);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--color-text)}.tx-detail-amount-card{text-align:center;padding:var(--space-3xl) var(--space-xl);margin-bottom:var(--space-lg);border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-lg)}.tx-detail-category-circle{width:68px;height:68px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-lg);font-size:28px}.tx-detail-amount{font-size:var(--text-4xl);font-family:var(--font-heading);color:var(--color-danger);letter-spacing:-.5px}.tx-detail-merchant{font-size:var(--text-md);font-weight:600;margin-top:var(--space-sm)}.tx-detail-date{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-xs)}.tx-detail-details-card{margin-bottom:var(--space-lg);border-radius:var(--radius-lg);padding:var(--space-xl);background:var(--color-surface);box-shadow:var(--shadow-md)}.tx-detail-row{display:flex;align-items:center;padding:var(--space-sm) 0}.tx-detail-row-icon{margin-right:var(--space-md);width:24px;text-align:center;font-size:18px;color:var(--color-muted)}.tx-detail-row-label{font-size:var(--text-sm);color:var(--color-text-secondary);flex:1}.tx-detail-row-value{font-size:var(--text-sm);font-weight:600;text-align:right;max-width:50%}.tx-detail-divider{height:1px;background:var(--color-border);margin:var(--space-md) 0}.tx-detail-source-badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:2px 10px;border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:600}.tx-detail-delete{margin-top:var(--space-xl)}.spending-detail-page{min-height:100vh}.spending-detail-topbar{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-2xl);padding-bottom:0}.spending-detail-back{width:36px;height:36px;border-radius:var(--radius-pill);background:var(--color-input-bg);display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--color-text)}.spending-detail-topbar h1{font-size:var(--text-xl);flex:1}.spending-detail-accent-bar{height:3px;width:100%}.spending-detail-content{padding:var(--space-xl);padding-bottom:var(--space-5xl)}.spending-detail-summary{text-align:center;padding:var(--space-2xl) var(--space-xl);margin-bottom:var(--space-xl);border-radius:var(--radius-xl);background:var(--color-surface);box-shadow:var(--shadow-lg)}.spending-detail-summary-label{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.spending-detail-summary-total{font-family:var(--font-heading);font-size:var(--text-3xl);letter-spacing:-.5px;margin-bottom:var(--space-xl)}.spending-detail-stats-row{display:flex;align-items:center;width:100%}.spending-detail-stat{flex:1;text-align:center}.spending-detail-stat-value{font-weight:600;font-size:var(--text-base);color:var(--color-text)}.spending-detail-stat-label{font-size:var(--text-xs);color:var(--color-text-secondary);margin-top:2px}.spending-detail-stat-divider{width:1px;height:30px;background:var(--color-border)}.spending-detail-trend-row{display:flex;align-items:center;justify-content:center;gap:2px}.spending-detail-month-selector{display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-xl);gap:var(--space-lg)}.spending-detail-month-arrow{width:36px;height:36px;border-radius:var(--radius-pill);background-color:var(--color-input-bg);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--color-text)}.spending-detail-month-arrow:disabled{opacity:.3}.spending-detail-month-label{font-weight:600;font-size:var(--text-md);color:var(--color-text);min-width:140px;text-align:center}.spending-detail-section{margin-bottom:var(--space-2xl)}.spending-detail-section-title{font-family:var(--font-heading);font-size:var(--text-lg);color:var(--color-text);margin-bottom:var(--space-lg)}.spending-detail-date-group{margin-bottom:var(--space-lg)}.spending-detail-date-label{font-weight:600;font-size:var(--text-sm);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-sm)}.spending-detail-tx-row{display:flex;align-items:center;background:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);margin-bottom:var(--space-sm);box-shadow:var(--shadow-sm);cursor:pointer;transition:opacity .15s}.spending-detail-tx-row:hover{opacity:.7}.spending-detail-tx-info{flex:1;min-width:0;margin-right:var(--space-sm)}.spending-detail-tx-name{font-weight:600;font-size:var(--text-sm);color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.spending-detail-tx-notes{font-size:var(--text-xs);color:var(--color-text-secondary);margin-top:2px}.spending-detail-tx-amount{font-weight:600;font-size:var(--text-sm);color:var(--color-accent);margin-right:var(--space-sm);flex-shrink:0}.spending-detail-tx-chevron{color:var(--color-muted);font-size:var(--text-sm)}.spending-detail-empty{text-align:center;padding:var(--space-3xl);background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.spending-detail-empty-icon{font-size:32px;color:var(--color-muted);margin-bottom:var(--space-md)}.spending-detail-loading{display:flex;flex-direction:column;align-items:center;padding:var(--space-5xl) 0;gap:var(--space-md)}
