.app-shell{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.app-shell__content{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.app-shell__nav{position:fixed;bottom:0;left:0;right:0;z-index:var(--z-sticky);display:flex;justify-content:space-around;align-items:center;box-sizing:border-box;height:calc(var(--nav-height) + var(--safe-area-bottom));padding-bottom:var(--safe-area-bottom);background:var(--color-surface);background:color-mix(in srgb,var(--color-surface) 85%,transparent);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-top:1px solid var(--color-border)}.app-shell__nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-1);flex:1;height:var(--nav-height);padding:var(--space-2);color:var(--color-text-muted);text-decoration:none;transition:all var(--duration-fast) var(--ease-out);min-width:44px;min-height:44px}.app-shell__nav-item:active{transform:scale(.92)}.app-shell__nav-item--active{color:var(--color-accent)}.app-shell__nav-item--active .app-shell__nav-icon{transform:scale(1.1)}.app-shell__nav-icon{display:flex;align-items:center;justify-content:center;transition:transform var(--duration-fast) var(--ease-spring)}.app-shell__nav-label{font-size:var(--text-xs);font-weight:var(--font-weight-medium)}@media(prefers-reduced-motion:reduce){.app-shell__nav-item:active,.app-shell__nav-item--active .app-shell__nav-icon{transform:none}}.transaction-sheet__overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);background:#00000080;animation:fadeIn var(--duration-fast) var(--ease-out)}.transaction-sheet{position:absolute;bottom:0;left:0;right:0;background:var(--color-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--space-4);padding-bottom:calc(var(--space-6) + var(--safe-area-bottom));animation:slideInFromBottom var(--duration-normal) var(--ease-out-expo)}.transaction-sheet__header{display:flex;justify-content:flex-end;margin-bottom:var(--space-2)}.transaction-sheet__close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--color-bg);color:var(--color-text-secondary);font-size:var(--text-lg)}.transaction-sheet__amount{display:flex;align-items:baseline;justify-content:center;gap:var(--space-2);margin-bottom:var(--space-3)}.transaction-sheet__currency{font-size:var(--text-2xl);color:var(--color-text-secondary)}.transaction-sheet__value{font-size:var(--text-3xl);font-weight:var(--font-weight-bold);font-variant-numeric:tabular-nums}.transaction-sheet__toggle{display:flex;gap:var(--space-2);margin-bottom:var(--space-4);padding:0 var(--space-4)}.transaction-sheet__toggle-btn{flex:1;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:var(--color-bg);border:1px solid var(--color-border);transition:all var(--duration-fast) var(--ease-out)}.transaction-sheet__toggle-btn--active{color:var(--color-danger);background:color-mix(in srgb,var(--color-danger) 10%,var(--color-bg));border-color:var(--color-danger)}.transaction-sheet__toggle-btn--income{color:var(--color-success)!important;background:color-mix(in srgb,var(--color-success) 10%,var(--color-bg))!important;border-color:var(--color-success)!important}.transaction-sheet__envelope-btn{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-4);margin-bottom:var(--space-4);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-align:left}.transaction-sheet__envelope-name{flex:1;font-weight:var(--font-weight-medium)}.transaction-sheet__envelope-balance{color:var(--color-text-secondary);font-size:var(--text-sm)}.transaction-sheet__envelope-placeholder{flex:1;color:var(--color-text-muted)}.transaction-sheet__chevron{color:var(--color-text-muted);font-size:var(--text-xl)}.transaction-sheet__optional{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.transaction-sheet__input{font-size:var(--text-sm);margin-bottom:var(--space-2)}.transaction-sheet__payee{position:relative;margin-bottom:var(--space-2)}.transaction-sheet__suggestions{position:absolute;top:100%;left:0;right:0;z-index:10;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);margin-top:var(--space-1);max-height:200px;overflow-y:auto}.transaction-sheet__suggestion{display:block;width:100%;padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-sm);transition:background var(--duration-fast) var(--ease-out)}.transaction-sheet__suggestion:hover{background:var(--color-bg)}.transaction-sheet__suggestion--create{color:var(--color-accent);border-top:1px solid var(--color-border)}.transaction-sheet__keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2);margin-bottom:var(--space-4)}.keypad-btn{height:56px;font-size:var(--text-xl);font-weight:var(--font-weight-medium);background:var(--color-bg);border-radius:var(--radius-lg);transition:all var(--duration-fast) var(--ease-out)}.keypad-btn:active{background:var(--color-border);transform:scale(.95)}.keypad-btn--action{font-size:var(--text-lg);color:var(--color-text-secondary)}.transaction-sheet__submit{width:100%}.transaction-sheet__submit:disabled{opacity:.5}.envelope-picker__overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:calc(var(--z-modal) + 1);background:#00000080;display:flex;align-items:flex-end;animation:fadeIn var(--duration-fast) var(--ease-out)}.envelope-picker{width:100%;max-height:80vh;background:var(--color-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--space-4);padding-bottom:calc(var(--space-4) + var(--safe-area-bottom));animation:slideInFromBottom var(--duration-normal) var(--ease-out-expo);display:flex;flex-direction:column}.envelope-picker__title{font-size:var(--text-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-3);text-align:center;flex-shrink:0}.envelope-picker__search{margin-bottom:var(--space-3);flex-shrink:0}.envelope-picker__list{display:flex;flex-direction:column;gap:var(--space-2);overflow-y:auto;flex:1;min-height:0}.envelope-picker__item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);background:var(--color-bg);border-radius:var(--radius-lg);border:2px solid transparent;text-align:left;min-height:48px;flex-shrink:0;transition:all var(--duration-fast) var(--ease-out)}.envelope-picker__item:hover{border-color:var(--color-border)}.envelope-picker__item--selected{border-color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 5%,var(--color-bg))}.envelope-picker__balance{color:var(--color-text-secondary);font-size:var(--text-sm);font-variant-numeric:tabular-nums}.envelope-picker__empty{text-align:center;padding:var(--space-8);color:var(--color-text-muted)}.envelope-modal__overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);background:#00000080;display:flex;align-items:center;justify-content:center;padding:var(--space-4);animation:fadeIn var(--duration-fast) var(--ease-out)}.envelope-modal{width:100%;max-width:400px;background:var(--color-surface);border-radius:var(--radius-xl);animation:scaleIn var(--duration-normal) var(--ease-out-expo);overflow:hidden}.envelope-modal__header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4);border-bottom:1px solid var(--color-border)}.envelope-modal__header-content{display:flex;align-items:center;gap:var(--space-3)}.envelope-modal__header-icon{flex-shrink:0;animation:fadeIn var(--duration-normal) var(--ease-out)}.envelope-modal__title{font-size:var(--text-lg);font-weight:var(--font-weight-semibold);font-family:var(--font-heading)}.envelope-modal__close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--color-bg);color:var(--color-text-secondary);font-size:var(--text-lg)}.envelope-modal__form{padding:var(--space-4)}.envelope-modal__amount-input{display:flex;align-items:center;gap:var(--space-2)}.envelope-modal__currency{font-size:var(--text-lg);color:var(--color-text-secondary)}.envelope-modal__hint{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-1)}.envelope-modal__error{color:var(--color-danger);font-size:var(--text-sm);margin-bottom:var(--space-4);padding:var(--space-3);background:color-mix(in srgb,var(--color-danger) 10%,var(--color-surface));border-radius:var(--radius-md)}.envelope-modal__actions{display:flex;gap:var(--space-3);margin-top:var(--space-4)}.envelope-modal__actions .btn{flex:1}.envelope-modal__color-picker{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--space-2);margin-top:var(--space-2)}.envelope-modal__color-swatch{width:100%;aspect-ratio:1;border-radius:var(--radius-md);border:2px solid transparent;cursor:pointer;transition:all var(--duration-fast) var(--ease-out);position:relative}.envelope-modal__color-swatch:hover{transform:scale(1.1);box-shadow:var(--shadow-md)}.envelope-modal__color-swatch--selected{border-color:var(--color-text-primary);transform:scale(1.15);box-shadow:var(--shadow-lg)}.envelope-modal__color-swatch--selected:after{content:"✓";position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:var(--font-weight-bold);font-size:var(--text-sm);text-shadow:0 1px 2px rgba(0,0,0,.3)}.envelope-modal__success{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);gap:var(--space-4);min-height:200px;animation:fadeIn var(--duration-normal) var(--ease-out)}.envelope-modal__success-icon{animation:scaleIn var(--duration-normal) var(--ease-out-expo)}.envelope-modal__success-title{font-size:var(--text-xl);font-weight:var(--font-weight-semibold);font-family:var(--font-heading);color:var(--color-success-text);text-align:center}.assign-modal__overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);background:#00000080;display:flex;align-items:flex-end;animation:fadeIn var(--duration-fast) var(--ease-out)}.assign-modal{width:100%;max-height:90vh;background:var(--color-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;display:flex;flex-direction:column;animation:slideInFromBottom var(--duration-normal) var(--ease-out-expo)}.assign-modal__header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4);border-bottom:1px solid var(--color-border);flex-shrink:0}.assign-modal__title{font-size:var(--text-lg);font-weight:var(--font-weight-semibold)}.assign-modal__close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--color-bg);color:var(--color-text-secondary);font-size:var(--text-lg)}.assign-modal__summary{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2);padding:var(--space-4);background:var(--color-bg);flex-shrink:0}.assign-modal__summary-item{text-align:center}.assign-modal__summary-label{display:block;font-size:var(--text-xs);color:var(--color-text-muted);margin-bottom:var(--space-1)}.assign-modal__summary-value{display:block;font-size:var(--text-sm);font-weight:var(--font-weight-semibold);font-variant-numeric:tabular-nums}.assign-modal__summary-value--negative{color:var(--color-danger)}.assign-modal__actions-top{display:flex;gap:var(--space-2);padding:var(--space-4);padding-bottom:0;flex-shrink:0}.assign-modal__actions-top .btn{flex:1}.assign-modal__list{flex:1;overflow-y:auto;padding:var(--space-3);min-height:0}.assign-modal__section-title{font-size:var(--text-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);margin-bottom:var(--space-2);margin-top:var(--space-3);padding-left:var(--space-1)}.assign-modal__section-title:first-child{margin-top:0}.assign-modal__row{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--color-surface);border-bottom:1px solid var(--color-border);min-height:48px}nn.assign-modal__row:last-child{border-bottom:none}.assign-modal__row-info{flex:1;min-width:0;overflow:hidden}.assign-modal__row-name{display:block;font-size:var(--text-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:1.3;word-break:break-word}.assign-modal__row-meta{display:block;font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:2px}.assign-modal__row-input{display:flex;align-items:center;gap:var(--space-1);flex-shrink:0}.assign-modal__currency{color:var(--color-text-secondary);font-size:var(--text-sm)}.assign-modal__amount{width:50px;padding:var(--space-1) var(--space-2);text-align:right;font-size:var(--text-sm);font-variant-numeric:tabular-nums}.assign-modal__footer{display:flex;gap:var(--space-3);padding:var(--space-4);padding-bottom:calc(var(--space-4) + var(--safe-area-bottom));border-top:1px solid var(--color-border);flex-shrink:0}.assign-modal__footer .btn{flex:1}.month-selector{display:flex;align-items:center;justify-content:center;gap:var(--space-2)}.month-selector__arrow{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--color-surface);border:1px solid var(--color-border);font-size:var(--text-xl);color:var(--color-text-secondary);transition:all var(--duration-fast) var(--ease-out)}.month-selector__arrow:active{transform:scale(.95);background:var(--color-bg)}.month-selector__current{display:flex;flex-direction:column;align-items:center;padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);min-width:140px;transition:background var(--duration-fast) var(--ease-out)}.month-selector__current:not(:disabled):hover{background:var(--color-bg)}.month-selector__text{font-size:var(--text-base);font-weight:var(--font-weight-semibold)}.month-selector__today-hint{font-size:var(--text-xs);color:var(--color-accent);margin-top:2px}.blueprint-modal__overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);background:#00000080;display:flex;align-items:flex-end;animation:fadeIn var(--duration-fast) var(--ease-out)}.blueprint-modal{width:100%;max-height:90vh;background:var(--color-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;display:flex;flex-direction:column;animation:slideInFromBottom var(--duration-normal) var(--ease-out-expo)}.blueprint-modal__header{position:relative;padding:var(--space-4);border-bottom:1px solid var(--color-border);flex-shrink:0}.blueprint-modal__title{font-size:var(--text-lg);font-weight:var(--font-weight-semibold)}.blueprint-modal__subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.blueprint-modal__close{position:absolute;top:var(--space-4);right:var(--space-4);width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--color-bg);color:var(--color-text-secondary);font-size:var(--text-lg)}.blueprint-modal__content{flex:1;overflow-y:auto;padding:var(--space-4)}.blueprint-modal__loading{text-align:center;color:var(--color-text-muted);padding:var(--space-8)}.blueprint-modal__types{display:flex;flex-direction:column;gap:var(--space-2)}.blueprint-modal__type{display:flex;flex-direction:column;align-items:flex-start;padding:var(--space-3);background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius-lg);text-align:left;transition:all var(--duration-fast) var(--ease-out)}.blueprint-modal__type:hover{border-color:var(--color-border-strong)}.blueprint-modal__type--active{border-color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 5%,var(--color-bg))}.blueprint-modal__type-label{font-weight:var(--font-weight-medium);margin-bottom:2px}.blueprint-modal__type-desc{font-size:var(--text-xs);color:var(--color-text-secondary)}.blueprint-modal__amount-input{display:flex;align-items:center;gap:var(--space-2)}.blueprint-modal__amount-input .input{flex:1;text-align:right;font-size:var(--text-lg);font-weight:var(--font-weight-semibold)}.blueprint-modal__currency{font-size:var(--text-lg);color:var(--color-text-secondary)}.blueprint-modal__footer{display:flex;gap:var(--space-3);padding:var(--space-4);padding-bottom:calc(var(--space-4) + var(--safe-area-bottom));border-top:1px solid var(--color-border);flex-shrink:0}.blueprint-modal__footer .btn{flex:1}.blueprint-modal__delete{flex:0 0 auto;width:auto}.blueprint-modal__confirm-text{flex:1;display:flex;align-items:center;font-weight:var(--font-weight-medium);color:var(--color-danger)}.group-modal__overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);background:#00000080;display:flex;align-items:center;justify-content:center;animation:fadeIn var(--duration-fast) var(--ease-out)}.group-modal{width:90%;max-width:400px;background:var(--color-surface);border-radius:var(--radius-xl);display:flex;flex-direction:column;animation:scaleIn var(--duration-normal) var(--ease-out-expo)}.group-modal__header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4);border-bottom:1px solid var(--color-border)}.group-modal__title{font-size:var(--text-lg);font-weight:var(--font-weight-semibold)}.group-modal__close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--color-bg);color:var(--color-text-secondary)}.group-modal__content{padding:var(--space-4)}.group-modal__footer{display:flex;gap:var(--space-2);padding:var(--space-4);border-top:1px solid var(--color-border)}.group-modal__footer .btn{flex:1}.group-modal__delete{flex:0 0 auto;width:auto}.group-modal__confirm-text{flex:1;display:flex;align-items:center;font-weight:var(--font-weight-medium);color:var(--color-danger)}.home__header{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-6)}.home__title{font-size:var(--text-2xl);font-weight:var(--font-weight-bold)}.home__available{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.home__available-label{font-size:var(--text-sm);color:var(--color-text-secondary)}.home__available-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:color-mix(in srgb,var(--color-success) 10%,transparent);border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-out)}.home__available-btn:hover:not(:disabled){background:color-mix(in srgb,var(--color-success) 20%,transparent)}.home__available-btn:disabled{background:transparent}.home__available-amount{font-size:var(--text-lg);font-weight:var(--font-weight-semibold);color:var(--color-success)}.home__available-btn:disabled .home__available-amount{color:var(--color-text-secondary)}.home__available-action{font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-success)}.home__search{margin-bottom:var(--space-4)}.home__search-field{position:relative}.home__search-input{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-sm)}.home__search-clear{position:absolute;right:var(--space-3);top:50%;transform:translateY(-50%);border:none;background:transparent;color:var(--color-text-muted);font-size:var(--text-lg);padding:var(--space-1);line-height:1}.home__search-hint{margin-top:var(--space-2);font-size:var(--text-xs);color:var(--color-text-muted)}.envelope-list{display:flex;flex-direction:column;gap:0}.envelope-row{background:var(--color-surface);border-radius:0;border:none;border-bottom:1px solid var(--color-border);animation:fadeIn var(--duration-normal) var(--ease-out)}.envelope-row:first-child{border-radius:var(--radius-lg) var(--radius-lg) 0 0}.envelope-row:last-child{border-radius:0 0 var(--radius-lg) var(--radius-lg);border-bottom:none}.envelope-row:only-child{border-radius:var(--radius-lg)}.envelope-row--expanded{border-color:var(--color-border-strong);border-left:3px solid var(--envelope-color, var(--color-primary))}.envelope-row--skeleton{animation:none;padding:var(--space-4);display:flex;justify-content:space-between;align-items:center;min-height:56px}.envelope-row__main{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);width:100%;min-height:48px;text-align:left}.envelope-row__main-wrapper{display:flex;align-items:center;width:100%}.envelope-row__info{flex:1;min-width:0}.envelope-row__name{display:block;font-weight:var(--font-weight-medium);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.envelope-row__right{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.envelope-row__balance{font-weight:var(--font-weight-semibold);font-variant-numeric:tabular-nums}.envelope-row__balance--negative{color:var(--color-danger-text)}.envelope-row__balance--low{color:var(--color-warning-text)}.envelope-row__chevron{font-size:var(--text-xl);color:var(--color-text-muted);transition:transform var(--duration-fast) var(--ease-out)}.envelope-row__chevron--open{transform:rotate(90deg)}.envelope-row__progress{height:8px;background:var(--color-border);border-radius:var(--radius-full);margin-top:var(--space-2);overflow:hidden}.envelope-row__progress--expanded{height:12px;margin-top:var(--space-3)}.envelope-row__progress-bar{height:100%;border-radius:var(--radius-full);transition:width var(--duration-slow) var(--ease-out-expo)}.envelope-row__progress-bar--overfunded{background:linear-gradient(90deg,var(--color-primary) 0%,#BB6BD9 100%)}.envelope-row__progress-bar--on-track{background:linear-gradient(90deg,var(--color-success) 0%,#56CCF2 100%)}.envelope-row__progress-bar--getting-there{background:linear-gradient(90deg,#56CCF2 0%,var(--color-success) 100%)}.envelope-row__progress-bar--behind{background:linear-gradient(90deg,var(--color-warning) 0%,#FF8C42 100%)}.envelope-row__details{padding:var(--space-3) var(--space-4);padding-top:0;animation:slideInFromTop var(--duration-fast) var(--ease-out)}@keyframes slideInFromTop{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.envelope-row__stats{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-bg);border-radius:var(--radius-md);margin-bottom:var(--space-2);font-size:var(--text-sm);flex-wrap:wrap}.envelope-row__stat{display:flex;align-items:baseline;gap:var(--space-1)}.envelope-row__stat:not(:last-child):after{content:"•";color:var(--color-text-muted);margin-left:var(--space-2)}.envelope-row__stat-label{font-size:var(--text-xs);color:var(--color-text-muted)}.envelope-row__stat-value{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-sm);font-weight:var(--font-weight-semibold);font-variant-numeric:tabular-nums}.envelope-row__stat-value--negative{color:var(--color-danger-text)}.envelope-row__stat-value--positive{color:var(--color-success-text)}.envelope-row__stat-type{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-weight-bold)}.envelope-row__stat-type--income{background:color-mix(in srgb,var(--color-success) 20%,transparent);color:var(--color-success)}.envelope-row__stat-type--expense{background:color-mix(in srgb,var(--color-danger) 20%,transparent);color:var(--color-danger)}.envelope-row__funding{margin-bottom:var(--space-2)}.envelope-row__funding-header{display:flex;justify-content:space-between;align-items:center;font-size:var(--text-sm);margin-bottom:var(--space-1)}.envelope-row__funding-status{font-weight:var(--font-weight-semibold);font-size:var(--text-sm)}.envelope-row__funding-status--overfunded{color:var(--color-primary-text)}.envelope-row__funding-status--on-track{color:var(--color-success-text)}.envelope-row__funding-status--getting-there{color:var(--color-info)}.envelope-row__funding-status--behind{color:var(--color-warning-text)}.envelope-row__funding-percent{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-1)}.envelope-row__actions{display:flex;gap:var(--space-2)}.envelope-row__actions .btn{flex:1}.text-positive{color:var(--color-success)}.text-warning{color:var(--color-warning)}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--text-sm)}.cold-start-message{text-align:center;padding:var(--space-6);color:var(--color-text-secondary);animation:fadeIn var(--duration-normal) var(--ease-out)}.cold-start-message__spinner{width:24px;height:24px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:var(--radius-full);margin:0 auto var(--space-3);animation:spin 1s linear infinite}.cold-start-message__hint{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-1)}.home__empty,.home__error{text-align:center;padding:var(--space-8);display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.home__empty-illustration{animation:fadeInUp var(--duration-slow) var(--ease-out-expo);margin-bottom:var(--space-2)}.home__empty-title{font-family:var(--font-heading);font-size:var(--heading-md);font-weight:var(--heading-weight);color:var(--color-text-primary);margin:0}.home__empty-text{color:var(--color-text-secondary);font-size:var(--text-base);max-width:320px;margin:0}.home__search-empty{text-align:center;padding:var(--space-6)}.home__empty h2,.home__error h2{font-size:var(--text-xl);margin-bottom:var(--space-2)}.home__empty p,.home__error p{color:var(--color-text-secondary);margin-bottom:var(--space-4)}.home__refreshing{position:fixed;top:var(--safe-area-top, 0);left:50%;transform:translate(-50%);padding:var(--space-2) var(--space-4);background:var(--color-surface);border-radius:var(--radius-full);box-shadow:var(--shadow-md);font-size:var(--text-sm);color:var(--color-text-secondary);z-index:var(--z-toast);animation:slideUp var(--duration-fast) var(--ease-out)}.home__fab{position:fixed;bottom:calc(var(--nav-height) + var(--safe-area-bottom) + var(--space-4));right:var(--space-4);z-index:var(--z-sticky);width:56px;height:56px;border-radius:var(--radius-full);background:var(--color-accent);color:#fff;font-size:var(--text-2xl);font-weight:var(--font-weight-bold);box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:center;transition:all var(--duration-fast) var(--ease-out)}.home__fab:hover{background:var(--color-accent-hover);transform:scale(1.05)}.home__fab:active{transform:scale(.95)}.envelope-group{margin-bottom:var(--space-2)}.envelope-group__header{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-2);margin-top:var(--space-2);background:transparent;color:var(--color-text-primary);font-weight:var(--font-weight-bold);font-size:var(--text-base);text-align:left;border-bottom:1px solid var(--color-border);transition:background var(--duration-fast) var(--ease-out);touch-action:none}.envelope-group__header:active{background:var(--color-surface)}.envelope-group__toggle{display:flex;align-items:center;justify-content:center;width:24px;height:24px;font-size:var(--text-base);color:var(--color-text-secondary)}.envelope-group__name{flex:1}.envelope-group__balance{font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.envelope-list__actions{display:flex;gap:var(--space-2);margin-top:var(--space-3)}.envelope-list__add-btn{flex:1;padding:var(--space-3);color:var(--color-text-secondary);font-size:var(--text-sm);text-align:center;border:2px dashed var(--color-border);border-radius:var(--radius-lg);transition:all var(--duration-fast) var(--ease-out)}.envelope-list__add-btn:hover{color:var(--color-accent);border-color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 5%,var(--color-bg))}.envelope-list__add-group{display:block;width:100%;padding:var(--space-3);margin-top:var(--space-3);color:var(--color-text-secondary);font-size:var(--text-sm);text-align:center;border:2px dashed var(--color-border);border-radius:var(--radius-lg);transition:all var(--duration-fast) var(--ease-out)}.envelope-list__add-group:hover{color:var(--color-accent);border-color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 5%,var(--color-bg))}.envelope-group__empty{padding:var(--space-4);text-align:center;color:var(--color-text-tertiary);font-size:var(--text-sm);background:var(--color-surface);border-radius:var(--radius-md);margin:var(--space-2) var(--space-4);border:1px dashed var(--color-border)}.envelope-group__empty--over{background:var(--color-surface-hover);border-color:var(--color-primary);color:var(--color-primary)}.accounts__header{margin-bottom:var(--space-6)}.accounts__title{font-size:var(--text-2xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-2)}.accounts__total{display:flex;justify-content:space-between;align-items:baseline;padding:var(--space-3) var(--space-4);background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.accounts__total-label{font-size:var(--text-sm);color:var(--color-text-secondary)}.accounts__total-amount{font-size:var(--text-lg);font-weight:var(--font-weight-semibold)}.accounts__list{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.account-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4);background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);min-height:56px;animation:fadeIn var(--duration-normal) var(--ease-out)}.account-row--skeleton{animation:none}.account-row__name{font-weight:var(--font-weight-medium)}.account-row__balance{font-weight:var(--font-weight-semibold);font-variant-numeric:tabular-nums}.accounts__empty,.accounts__error{text-align:center;padding:var(--space-8)}.accounts__empty h2{font-size:var(--text-xl);margin-bottom:var(--space-2)}.accounts__empty p{color:var(--color-text-secondary);margin-bottom:var(--space-4)}.accounts__add-btn{width:100%}.create-account-form{padding:var(--space-4);animation:fadeIn var(--duration-normal) var(--ease-out)}.create-account-form__title{font-size:var(--text-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-4)}.create-account-form__amount{display:flex;align-items:center;gap:var(--space-2)}.create-account-form__currency{font-size:var(--text-lg);color:var(--color-text-secondary)}.create-account-form__error{color:var(--color-danger);font-size:var(--text-sm);margin-bottom:var(--space-4);padding:var(--space-3);background:color-mix(in srgb,var(--color-danger) 10%,var(--color-surface));border-radius:var(--radius-md)}.create-account-form__actions{display:flex;gap:var(--space-3);margin-top:var(--space-4)}.create-account-form__actions .btn{flex:1}.edit-modal__overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);background:#00000080;display:flex;align-items:flex-end;animation:fadeIn var(--duration-fast) var(--ease-out)}.edit-modal{width:100%;max-height:90vh;background:var(--color-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;display:flex;flex-direction:column;animation:slideInFromBottom var(--duration-normal) var(--ease-out-expo)}.edit-modal__header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4);border-bottom:1px solid var(--color-border);flex-shrink:0}.edit-modal__header-content{display:flex;align-items:center;gap:var(--space-3)}.edit-modal__header-icon{flex-shrink:0;animation:fadeIn var(--duration-normal) var(--ease-out)}.edit-modal__title{font-size:var(--text-lg);font-weight:var(--font-weight-semibold);font-family:var(--font-heading)}.edit-modal__close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--color-bg);color:var(--color-text-secondary);font-size:var(--text-lg)}.edit-modal__content{flex:1;overflow-y:auto;padding:var(--space-4)}.edit-modal__amount-input{display:flex;align-items:center;gap:var(--space-2)}.edit-modal__amount-input .input{flex:1;text-align:right;font-size:var(--text-lg);font-weight:var(--font-weight-semibold)}.edit-modal__currency{font-size:var(--text-lg);color:var(--color-text-secondary)}.edit-modal__type-toggle{display:flex;gap:var(--space-2);padding:var(--space-1);background:var(--color-bg);border-radius:var(--radius-lg)}.edit-modal__type-btn{flex:1;padding:var(--space-3);border-radius:var(--radius-md);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);transition:all var(--duration-fast) var(--ease-out)}.edit-modal__type-btn--active{background:var(--color-surface);color:var(--color-danger);box-shadow:var(--shadow-sm)}.edit-modal__type-btn--income{color:var(--color-success)}.edit-modal__select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;background-size:16px;padding-right:var(--space-10)}.edit-modal__footer{display:flex;gap:var(--space-3);padding:var(--space-4);padding-bottom:calc(var(--space-4) + var(--safe-area-bottom));border-top:1px solid var(--color-border);flex-shrink:0}.edit-modal__footer .btn{flex:1}.edit-modal__delete{flex:0 0 auto;width:auto}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:color-mix(in srgb,var(--color-danger) 85%,black)}.edit-modal__envelope-btn{display:flex;justify-content:space-between;align-items:center;text-align:left;cursor:pointer}.edit-modal__envelope-placeholder{color:var(--color-text-muted)}.edit-modal__envelope-balance{color:var(--color-text-secondary);font-size:var(--text-sm);font-variant-numeric:tabular-nums}.edit-modal__envelope-picker{margin-top:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.edit-modal__envelope-picker .input{border-radius:0;border:none;border-bottom:1px solid var(--color-border)}.edit-modal__envelope-list{max-height:200px;overflow-y:auto}.edit-modal__envelope-option{display:flex;justify-content:space-between;align-items:center;width:100%;padding:var(--space-3) var(--space-4);text-align:left;border-bottom:1px solid var(--color-border);transition:background var(--duration-fast) var(--ease-out)}.edit-modal__envelope-option:last-child{border-bottom:none}.edit-modal__envelope-option:hover{background:var(--color-bg)}.edit-modal__envelope-option--selected{background:color-mix(in srgb,var(--color-accent) 10%,var(--color-surface))}.edit-modal__payee-wrapper{position:relative}.edit-modal__payee-list{position:absolute;top:100%;left:0;right:0;z-index:10;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);margin-top:var(--space-1);max-height:150px;overflow-y:auto}.edit-modal__payee-option{display:block;width:100%;padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-sm);border-bottom:1px solid var(--color-border);transition:background var(--duration-fast) var(--ease-out)}.edit-modal__payee-option:last-child{border-bottom:none}.edit-modal__payee-option:hover{background:var(--color-bg)}.edit-modal__success{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);gap:var(--space-4);min-height:200px;animation:fadeIn var(--duration-normal) var(--ease-out)}.edit-modal__success-icon{animation:scaleIn var(--duration-normal) var(--ease-out-expo)}.edit-modal__success-title{font-size:var(--text-xl);font-weight:var(--font-weight-semibold);font-family:var(--font-heading);color:var(--color-success-text);text-align:center}.transactions__header{margin-bottom:var(--space-4)}.transactions__title{font-size:var(--text-2xl);font-weight:var(--font-weight-bold)}.transactions__tabs{display:flex;gap:var(--space-1);padding:var(--space-1);background:var(--color-bg);border-radius:var(--radius-lg);margin-bottom:var(--space-4)}.transactions__tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3);border-radius:var(--radius-md);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);transition:all var(--duration-fast) var(--ease-out)}.transactions__tab--active{background:var(--color-surface);color:var(--color-text-primary);box-shadow:var(--shadow-sm)}.transactions__tab-badge{min-width:20px;height:20px;padding:0 var(--space-1);background:var(--color-accent);color:#fff;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-weight-bold);display:flex;align-items:center;justify-content:center}.transactions__list{display:flex;flex-direction:column;gap:var(--space-4)}.transactions__date-group{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden}.transactions__date-header{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);background:var(--color-bg);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:1}.transaction-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);min-height:48px;text-align:left;width:100%;border-bottom:1px solid var(--color-border);transition:background var(--duration-fast) var(--ease-out)}.transaction-row:last-child{border-bottom:none}.transaction-row--expense{background:color-mix(in srgb,var(--color-danger) 3%,var(--color-surface))}.transaction-row--skeleton{animation:none}.transaction-row--unassigned{position:relative;background:color-mix(in srgb,var(--color-warning) 5%,var(--color-surface))}.transaction-row--unassigned:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--color-warning)}.transaction-row__left{display:flex;align-items:center;gap:var(--space-3);flex:1;min-width:0}.transaction-row__type{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-full);font-size:var(--text-lg);font-weight:var(--font-weight-bold);flex-shrink:0}.transaction-row__type--income{background:color-mix(in srgb,var(--color-success) 15%,transparent);color:var(--color-success)}.transaction-row__type--expense{background:color-mix(in srgb,var(--color-text-secondary) 10%,transparent);color:var(--color-text-secondary)}.transaction-row__info{flex:1;min-width:0}.transaction-row__payee{display:block;font-weight:var(--font-weight-medium);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.transaction-row__meta{display:block;font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.transaction-row__amount{font-weight:var(--font-weight-semibold);font-variant-numeric:tabular-nums;flex-shrink:0}.transaction-row--expense .transaction-row__amount{color:var(--color-danger)}.transaction-row__amount--positive{color:var(--color-success)}.transaction-row__actions{display:flex;align-items:center;gap:var(--space-3)}.transactions__load-more{margin-top:var(--space-4);padding:0 var(--space-2)}.transactions__load-more-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);background:var(--color-surface);border:2px dashed var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-secondary);font-size:var(--text-sm);font-weight:var(--font-weight-medium);transition:all var(--duration-fast) var(--ease-out)}.transactions__load-more-btn:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 5%,var(--color-surface))}.transactions__load-more-btn:disabled{opacity:.6;cursor:not-allowed}.transactions__load-more-icon{font-size:var(--text-lg)}.transactions__load-more-spinner{width:16px;height:16px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:var(--radius-full);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.transactions__empty{text-align:center;padding:var(--space-8);display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.transactions__empty-illustration{animation:fadeInUp var(--duration-slow) var(--ease-out-expo);margin-bottom:var(--space-2)}.transactions__empty-title{font-family:var(--font-heading);font-size:var(--heading-md);font-weight:var(--heading-weight);color:var(--color-text-primary);margin:0}.transactions__empty-text{color:var(--color-text-secondary);font-size:var(--text-base);max-width:320px;margin:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.settings__header{margin-bottom:var(--space-6)}.settings__title{font-size:var(--text-2xl);font-weight:var(--font-weight-bold)}.settings__content{display:flex;flex-direction:column;gap:var(--space-6)}.settings__footer{margin-top:var(--space-8);text-align:center;color:var(--color-text-muted);font-size:var(--text-sm)}.settings__footer p{margin-bottom:var(--space-1)}.settings-section{margin-bottom:var(--space-2)}.settings-section__title{font-size:var(--text-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3)}.theme-selector{display:flex;gap:var(--space-2);padding:var(--space-1);background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.theme-selector__option{flex:1;padding:var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:transparent;transition:all var(--duration-fast) var(--ease-out)}.theme-selector__option:hover{background:var(--color-bg)}.theme-selector__option--active{background:var(--color-bg);color:var(--color-text-primary);box-shadow:var(--shadow-sm)}.budget-selector{display:flex;flex-direction:column;gap:var(--space-2)}.budget-selector__option{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4);background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-lg);text-align:left;transition:all var(--duration-fast) var(--ease-out)}.budget-selector__option:hover{border-color:var(--color-border-strong)}.budget-selector__option--active{border-color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 5%,var(--color-surface))}.budget-selector__name{font-weight:var(--font-weight-medium)}.budget-selector__check{color:var(--color-accent);font-weight:var(--font-weight-bold)}.budget-selector__empty{color:var(--color-text-muted);text-align:center;padding:var(--space-4)}.settings-create-btn{width:100%;margin-top:var(--space-3)}.settings-create-form{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-top:var(--space-3)}.settings-create-form__actions{display:flex;gap:var(--space-2)}.settings-create-form__actions .btn{flex:1}.settings-account{display:flex;justify-content:space-between;align-items:center}.settings-account__email{font-weight:var(--font-weight-medium)}.debug-panel__toggle{width:100%;display:flex;justify-content:space-between;align-items:center;padding:var(--space-4);background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);transition:all var(--duration-fast) var(--ease-out)}.debug-panel__toggle:hover{background:var(--color-bg)}.debug-panel__toggle-icon{font-size:var(--text-xs)}.debug-panel{margin-top:var(--space-2);animation:slideUp var(--duration-fast) var(--ease-out)}.debug-panel__row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) 0;border-bottom:1px solid var(--color-border)}.debug-panel__row:last-child{border-bottom:none}.debug-panel__label{font-size:var(--text-sm);color:var(--color-text-secondary)}.debug-panel__value{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm)}.debug-panel__status{font-weight:var(--font-weight-medium)}.debug-panel__status--ok{color:var(--color-positive)}.debug-panel__status--error{color:var(--color-negative)}.debug-panel__status--warm{color:var(--color-positive)}.debug-panel__status--cold{color:var(--color-info)}.debug-panel__latency{color:var(--color-text-muted);font-size:var(--text-xs)}.debug-panel__code{font-family:monospace;font-size:var(--text-xs);padding:var(--space-1) var(--space-2);background:var(--color-bg);border-radius:var(--radius-sm);cursor:pointer}.debug-panel__code:hover{background:var(--color-border)}.debug-panel__action{padding:var(--space-1) var(--space-2);font-size:var(--text-xs)}.debug-panel__loading{color:var(--color-text-muted)}.onboarding{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:var(--space-6)}.onboarding__content{width:100%;max-width:400px;animation:fadeIn var(--duration-normal) var(--ease-out)}.onboarding__header{text-align:center;margin-bottom:var(--space-8)}.onboarding__logo{margin-bottom:var(--space-4);animation:scaleIn var(--duration-slow) var(--ease-spring);display:inline-block}.onboarding__title{font-family:var(--font-heading);font-size:var(--heading-lg);font-weight:var(--heading-weight);margin-bottom:var(--space-2);color:var(--color-text-primary)}.onboarding__subtitle{color:var(--color-text-secondary)}.onboarding__form{padding:var(--space-6)}.form-group{margin-bottom:var(--space-5)}.currency-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2)}.currency-option{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);transition:all var(--duration-fast) var(--ease-out)}.currency-option:hover{border-color:var(--color-border-strong)}.currency-option--active{border-color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 5%,var(--color-surface))}.currency-option__symbol{font-size:var(--text-xl);font-weight:var(--font-weight-bold)}.currency-option__label{font-size:var(--text-xs);color:var(--color-text-secondary)}.onboarding__error{color:var(--color-danger);font-size:var(--text-sm);margin-bottom:var(--space-4);padding:var(--space-3);background:color-mix(in srgb,var(--color-danger) 10%,var(--color-surface));border-radius:var(--radius-md)}.onboarding__submit{width:100%;margin-top:var(--space-2)}.onboarding__help{text-align:center;margin-top:var(--space-6);font-size:var(--text-sm);color:var(--color-text-muted)}.install-prompt{position:fixed;bottom:0;left:0;right:0;z-index:var(--z-modal);background:var(--color-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;box-shadow:var(--shadow-xl);padding:var(--space-6);padding-bottom:calc(var(--space-6) + var(--safe-area-bottom));animation:slideInFromBottom var(--duration-normal) var(--ease-out-expo)}.install-prompt--closing{animation:slideOutToBottom var(--duration-fast) var(--ease-out) forwards}@keyframes slideOutToBottom{to{transform:translateY(100%)}}.install-prompt__close{position:absolute;top:var(--space-4);right:var(--space-4);display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-full);color:var(--color-text-muted);background:var(--color-bg);transition:all var(--duration-fast) var(--ease-out)}.install-prompt__close:hover{background:var(--color-border);color:var(--color-text-primary)}.install-prompt__content{max-width:320px;margin:0 auto;text-align:center}.install-prompt__title{font-size:var(--text-xl);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-3)}.install-prompt__text{color:var(--color-text-secondary);margin-bottom:var(--space-4)}.install-prompt__steps{list-style:none;text-align:left}.install-prompt__steps li{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);margin-bottom:var(--space-2);background:var(--color-bg);border-radius:var(--radius-md)}.install-prompt__steps li svg{color:var(--color-accent);flex-shrink:0}.install-prompt__install-btn{width:100%}:root{--color-bg: #FDFBF9;--color-surface: #FFFFFF;--color-surface-elevated: #FFFFFF;--color-border: rgba(0, 0, 0, .08);--color-border-strong: rgba(0, 0, 0, .15);--color-text-primary: #1A1A1A;--color-text-secondary: #666666;--color-text-muted: #757575;--color-primary: #8B6FD9;--color-primary-hover: #7C5CDB;--color-primary-light: #A689E3;--color-envelope-green: #6FCF97;--color-envelope-blue: #56CCF2;--color-envelope-purple: #BB6BD9;--color-envelope-pink: #F2819F;--color-envelope-yellow: #F2C94C;--color-envelope-teal: #2D9CDB;--color-envelope-orange: #FF8C42;--color-success: #6FCF97;--color-warning: #FF8C42;--color-danger: #EB5757;--color-info: #56CCF2;--color-success-text: #2E7D4E;--color-warning-text: #B8860B;--color-danger-text: #D32F2F;--color-primary-text: #5E3FA3;--color-accent: var(--color-primary);--color-accent-hover: var(--color-primary-hover);--color-positive: var(--color-success);--color-negative: var(--color-danger);--color-neutral: var(--color-text-secondary);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-heading: "Outfit", var(--font-family);--font-body: var(--font-family);--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--heading-xs: 1rem;--heading-sm: 1.25rem;--heading-md: 1.5rem;--heading-lg: 2rem;--heading-xl: 2.5rem;--heading-weight: 600;--line-height-tight: 1.2;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--gradient-primary: linear-gradient(135deg, #FF8C42 0%, #FF7526 100%);--gradient-success: linear-gradient(135deg, #6FCF97 0%, #56CCF2 100%);--gradient-getting-there: linear-gradient(135deg, #56CCF2 0%, #6FCF97 100%);--gradient-behind: linear-gradient(135deg, #F2C94C 0%, #FF8C42 100%);--gradient-celebration: linear-gradient(135deg, #BB6BD9 0%, #F2819F 100%);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .06);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .08);--shadow-xl: 0 8px 32px rgba(0, 0, 0, .1);--ease-out: cubic-bezier(.33, 1, .68, 1);--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--duration-instant: .1s;--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s;--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-modal: 300;--z-toast: 400;--z-tooltip: 500;--safe-area-top: env(safe-area-inset-top);--safe-area-bottom: env(safe-area-inset-bottom);--safe-area-left: env(safe-area-inset-left);--safe-area-right: env(safe-area-inset-right);--nav-height: 56px;--max-content-width: 600px}[data-theme=dark]{--color-bg: #121212;--color-surface: #1E1E1E;--color-surface-elevated: #2A2A2A;--color-border: rgba(255, 255, 255, .08);--color-border-strong: rgba(255, 255, 255, .15);--color-text-primary: #FAFAFA;--color-text-secondary: #A0A0A0;--color-text-muted: #8F8F8F;--color-primary: #A689E3;--color-primary-hover: #B89EE8;--color-primary-light: #C9B3ED;--color-envelope-green: #7FDB9E;--color-envelope-blue: #6DD9FF;--color-envelope-purple: #C980E0;--color-envelope-pink: #FF94AE;--color-envelope-yellow: #FFD666;--color-envelope-teal: #47B0ED;--color-envelope-orange: #FFA366;--color-success: #7FDB9E;--color-warning: #FFA366;--color-danger: #FF6B6B;--color-info: #6DD9FF;--color-success-text: #7FDB9E;--color-warning-text: #FFA366;--color-danger-text: #FF8080;--color-primary-text: #B89EE8;--color-accent: var(--color-primary);--color-accent-hover: var(--color-primary-hover);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 2px 8px rgba(0, 0, 0, .3);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .4);--shadow-xl: 0 8px 32px rgba(0, 0, 0, .5)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-family);font-size:var(--text-base);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg);min-height:100vh;min-height:100dvh;overscroll-behavior:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@supports (padding-bottom: env(safe-area-inset-bottom)){body{padding-bottom:var(--safe-area-bottom)}}a{color:var(--color-accent);text-decoration:none}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none}input,textarea,select{font-family:inherit;font-size:inherit}.page{min-height:100vh;min-height:100dvh;padding:var(--space-4);padding-bottom:calc(var(--nav-height) + var(--safe-area-bottom) + var(--space-4));max-width:var(--max-content-width);margin:0 auto}.auth-page{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skeleton{background:linear-gradient(90deg,var(--color-border) 25%,var(--color-surface) 50%,var(--color-border) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md)}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideInFromBottom{0%{transform:translateY(100%)}to{transform:translateY(0)}}.card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-weight:var(--font-weight-medium);transition:all var(--duration-fast) var(--ease-out);min-height:44px;min-width:44px}.btn-primary{background:var(--color-accent);color:#fff}.btn-primary:hover{background:var(--color-accent-hover)}.btn-secondary{background:var(--color-surface-elevated);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-bg)}.input{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-primary);transition:border-color var(--duration-fast) var(--ease-out);min-height:44px}.input:focus{outline:none;border-color:var(--color-accent)}.input::placeholder{color:var(--color-text-muted)}.form-group{margin-bottom:var(--space-4)}.form-label{display:block;font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}@keyframes successPulse{0%{box-shadow:0 0 #4a7c5966}70%{box-shadow:0 0 0 10px #4a7c5900}to{box-shadow:0 0 #4a7c5900}}.success-pulse{animation:successPulse .6s var(--ease-out)}.card-glass{background:#ffffffb3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-lg);padding:var(--space-4)}[data-theme=dark] .card-glass{background:#1e1e1ecc;border:1px solid rgba(255,255,255,.1)}.toast{position:fixed;bottom:calc(var(--nav-height) + var(--safe-area-bottom) + var(--space-8));left:50%;transform:translate(-50%);padding:var(--space-3) var(--space-6);background:var(--color-success, var(--color-accent));color:#fff;border-radius:var(--radius-full);font-weight:var(--font-weight-medium);box-shadow:var(--shadow-lg);z-index:var(--z-toast);animation:slideUp var(--duration-normal) var(--ease-out-expo)}.haptic-trigger:active{-webkit-tap-highlight-color:rgba(74,124,89,.2)}.pull-refresh{position:fixed;top:var(--safe-area-top);left:50%;transform:translate(-50%) translateY(-100%);padding:var(--space-2) var(--space-4);background:var(--color-surface);border-radius:var(--radius-full);box-shadow:var(--shadow-md);transition:transform var(--duration-fast) var(--ease-out);z-index:var(--z-sticky)}.pull-refresh--visible{transform:translate(-50%) translateY(var(--space-4))}:root{--color-success: #4A7C59}[data-theme=dark]{--color-success: #6AAF7B}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
