.bottom-nav{height:calc(var(--bottom-nav-height) + var(--safe-area-bottom));padding-bottom:var(--safe-area-bottom);background:var(--color-surface);border-top:1px solid var(--color-border);z-index:100;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 8px #0000000f}.bottom-nav__item{height:var(--bottom-nav-height);color:var(--color-text-muted);transition:color var(--transition-fast);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;padding:0;display:flex}.bottom-nav__item--active{color:var(--color-primary)}.bottom-nav__icon{font-size:22px;line-height:1}.bottom-nav__label{letter-spacing:.02em;font-size:10px;font-weight:500}.app-shell{flex-direction:column;width:100%;max-width:480px;min-height:100dvh;margin:0 auto;display:flex;position:relative}.app-shell__content{padding-bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom) + var(--spacing-md));-webkit-overflow-scrolling:touch;flex:1;overflow:hidden auto}.toast-container{top:calc(var(--spacing-md) + env(safe-area-inset-top,0px));z-index:300;gap:var(--spacing-sm);width:calc(100% - var(--spacing-md) * 2);pointer-events:none;flex-direction:column;max-width:440px;display:flex;position:fixed;left:50%;transform:translate(-50%)}.toast{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-lg);pointer-events:auto;min-height:var(--touch-min);animation:.3s toastSlideDown;display:flex;transform:translate(0)}.toast--exit{animation:.3s forwards toastSlideUp}.toast--success{border-left:3px solid var(--color-primary)}.toast--error{border-left:3px solid var(--color-danger)}.toast--info{border-left:3px solid var(--color-info)}.toast--warning{border-left:3px solid var(--color-warning)}.toast__icon{flex-shrink:0;font-size:18px}.toast__message{color:var(--color-text);font-size:14px;line-height:1.4}@keyframes toastSlideDown{0%{opacity:0;transform:translate(-50%)translateY(-100%)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes toastSlideUp{0%{opacity:1;transform:translate(-50%)translateY(0)}to{opacity:0;transform:translate(-50%)translateY(-100%)}}.pin-input{align-items:center;gap:var(--spacing-md);flex-direction:column;display:flex}.pin-input__label{color:var(--color-text);margin-bottom:var(--spacing-xs);font-size:14px;font-weight:500}.pin-input__dots{gap:var(--spacing-md);display:flex}.pin-input__dot{border:2px solid var(--color-border);width:12px;height:12px;transition:all var(--transition-fast);background:0 0;border-radius:50%}.pin-input__dot--filled{background:var(--color-primary);border-color:var(--color-primary);transform:scale(1.1)}.pin-input__numpad{flex-direction:column;gap:6px;width:100%;max-width:260px;display:flex}.pin-input__row{gap:6px;display:flex}.pin-input__key{border-radius:var(--radius-md);height:48px;color:var(--color-text);background:var(--color-surface);transition:background var(--transition-fast);box-shadow:var(--shadow-sm);flex:1;justify-content:center;align-items:center;font-size:20px;font-weight:500;display:flex}.pin-input__key:active:not(:disabled){background:var(--color-primary-light)}.pin-input__key--empty{box-shadow:none;background:0 0}.login-page{height:100dvh;padding:0 var(--spacing-md) env(safe-area-inset-bottom,16px);background:linear-gradient(180deg, var(--color-primary-light) 0%, var(--color-bg) 60%);flex-direction:column;align-items:center;display:flex;overflow:hidden}.login-page__header{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:0;display:flex}.login-page__logo{margin-bottom:var(--spacing-xs);font-size:48px}.login-page__title{color:var(--color-primary-dark);font-size:26px;font-weight:700}.login-page__subtitle{color:var(--color-text-secondary);margin-top:4px;font-size:13px}.login-page__prompt{color:var(--color-text-secondary);text-align:center;margin-bottom:var(--spacing-md);font-size:14px}.login-page__users{width:100%;max-width:320px;padding-bottom:var(--spacing-xl)}.login-page__user-list{gap:var(--spacing-sm);flex-direction:column;display:flex}.login-page__user-btn{align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);width:100%;min-height:var(--touch-comfortable);display:flex}.login-page__avatar{font-size:32px}.login-page__name{font-size:17px;font-weight:600}.login-page__pin-section{width:100%;max-width:320px;padding-bottom:var(--spacing-sm);flex-direction:column;flex-shrink:0;align-items:center;display:flex}.login-page__back{color:var(--color-primary);margin-bottom:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);font-size:13px}.login-page__hint{margin-top:var(--spacing-sm);color:var(--color-text-muted);font-size:11px}.amount{font-variant-numeric:tabular-nums;white-space:nowrap;text-overflow:ellipsis;max-width:100%;display:inline-block;overflow:hidden}.amount--income{color:var(--color-income)}.amount--expense{color:var(--color-expense)}.amount--neutral{color:var(--color-text)}.amount--sm{font-size:clamp(12px,3.5vw,14px);font-weight:500}.amount--md{font-size:clamp(14px,4vw,18px);font-weight:600}.amount--lg{font-size:clamp(18px,5vw,24px);font-weight:700}.tx-card{align-items:center;gap:var(--spacing-sm);background:var(--color-surface);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);box-shadow:var(--shadow-sm);flex-wrap:wrap;display:flex;position:relative}.tx-card__icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex}.tx-card__info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.tx-card__name{color:var(--color-text);font-size:14px;font-weight:600}.tx-card__desc{color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.tx-card__date,.tx-card__meta{color:var(--color-text-muted);font-size:11px}.tx-card__right{text-align:right;flex-direction:column;flex-shrink:0;align-items:flex-end;gap:2px;display:flex}.tx-card__status{border-radius:var(--radius-full);padding:2px 6px;font-size:10px;font-weight:600}.tx-card__status--pending{background:var(--color-warning-light);color:var(--color-warning)}.tx-card__status--approved{background:var(--color-primary-light);color:var(--color-primary-dark)}.tx-card__status--rejected{background:var(--color-danger-light);color:var(--color-danger)}.tx-card__actions{gap:var(--spacing-sm);width:100%;margin-top:var(--spacing-xs);padding-top:var(--spacing-xs);border-top:1px solid var(--color-border);display:flex}.tx-card__btn{height:var(--touch-min);border-radius:var(--radius-sm);flex:1;font-size:14px;font-weight:600}.tx-card__btn--approve{background:var(--color-primary);color:#fff}.tx-card__btn--reject{background:var(--color-danger-light);color:var(--color-danger)}.tx-card__recall-inline{border-radius:var(--radius-full);background:var(--color-warning-light);color:var(--color-warning);border:1px solid var(--color-warning);white-space:nowrap;padding:2px 10px;font-size:11px;font-weight:600}.tx-card__status--recalled{color:#64748b;background:#e2e8f0}.bottom-sheet__overlay{z-index:200;background:#0006;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.bottom-sheet__panel{background:var(--color-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:480px;max-height:90dvh;padding-bottom:var(--safe-area-bottom);will-change:transform;flex-direction:column;animation:.3s sheetSlideUp;display:flex}.bottom-sheet__handle{background:var(--color-border);border-radius:var(--radius-full);width:36px;height:4px;margin:var(--spacing-sm) auto var(--spacing-xs);flex-shrink:0}.bottom-sheet__title{padding:var(--spacing-xs) var(--spacing-md) var(--spacing-sm);text-align:center;font-size:17px;font-weight:600}.bottom-sheet__body{-webkit-overflow-scrolling:touch;padding:0 var(--spacing-md) var(--spacing-md);flex:1;overflow-y:auto}.confirm-sheet{text-align:center;padding:var(--spacing-md) 0}.confirm-sheet__message{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg);white-space:pre-line;text-align:left;font-size:15px;line-height:1.6}.confirm-sheet__actions{gap:var(--spacing-sm);display:flex}.confirm-sheet__btn{height:var(--touch-comfortable);border-radius:var(--radius-md);transition:opacity var(--transition-fast);flex:1;font-size:15px;font-weight:600}.confirm-sheet__btn:active{opacity:.8}.confirm-sheet__btn--cancel{background:var(--color-bg);color:var(--color-text-secondary)}.confirm-sheet__btn--confirm.confirm-sheet__btn--primary{background:var(--color-primary);color:#fff}.confirm-sheet__btn--confirm.confirm-sheet__btn--danger{background:var(--color-danger);color:#fff}.dashboard{padding:var(--spacing-md);padding-top:calc(var(--spacing-md) + env(safe-area-inset-top,0px))}.dashboard__header{margin-bottom:var(--spacing-md)}.dashboard__greeting{font-size:20px;font-weight:700}.dashboard__month{color:var(--color-text-secondary);margin-top:2px;font-size:13px}.dashboard__summary{gap:var(--spacing-sm);scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:var(--spacing-sm);margin-bottom:var(--spacing-md);display:flex;overflow-x:auto}.dashboard__summary::-webkit-scrollbar{display:none}.summary-card{flex:0 0 calc(50% - var(--spacing-xs));scroll-snap-align:start;background:var(--color-surface);border-radius:var(--radius-md);padding:var(--spacing-md);box-shadow:var(--shadow-sm);gap:var(--spacing-xs);flex-direction:column;min-width:140px;display:flex}.summary-card__label{color:var(--color-text-muted);font-size:12px;font-weight:500}.summary-card--income{border-left:3px solid var(--color-income)}.summary-card--expense{border-left:3px solid var(--color-expense)}.summary-card--balance{border-left:3px solid var(--color-info)}.dashboard__section{margin-bottom:var(--spacing-lg)}.dashboard__section-title{margin-bottom:var(--spacing-sm);font-size:16px;font-weight:600}.dashboard__tx-list{gap:var(--spacing-sm);flex-direction:column;display:flex}.tx-detail{gap:var(--spacing-md);flex-direction:column;display:flex}.tx-detail__row{justify-content:space-between;align-items:center;font-size:14px;display:flex}.tx-detail__row>span:first-child{color:var(--color-text-secondary)}.input-page{padding:var(--spacing-md);padding-top:calc(var(--spacing-md) + env(safe-area-inset-top,0px))}.input-page__header h1{margin-bottom:var(--spacing-md);font-size:20px;font-weight:700}.input-page__toggle{background:var(--color-bg);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);padding:3px;display:flex}.toggle-btn{border-radius:var(--radius-sm);height:40px;color:var(--color-text-secondary);transition:all var(--transition-fast);flex:1;font-size:14px;font-weight:600}.toggle-btn--active{background:var(--color-surface);box-shadow:var(--shadow-sm);color:var(--color-text)}.toggle-btn--expense.toggle-btn--active{color:var(--color-expense)}.toggle-btn--income.toggle-btn--active{color:var(--color-income)}.input-page__amount-display{text-align:center;padding:var(--spacing-md) 0;margin-bottom:var(--spacing-sm)}.input-page__amount{font-variant-numeric:tabular-nums;font-size:clamp(24px,8vw,36px);font-weight:700}.input-page__numpad{gap:var(--spacing-xs);margin-bottom:var(--spacing-md);flex-direction:column;display:flex}.input-page__numpad-row{gap:var(--spacing-xs);display:flex}.input-page__numpad-key{border-radius:var(--radius-sm);background:var(--color-surface);height:48px;color:var(--color-text);box-shadow:var(--shadow-sm);flex:1;justify-content:center;align-items:center;font-size:20px;font-weight:500;display:flex}.input-page__numpad-key:active{background:var(--color-primary-light)}.input-page__section{margin-bottom:var(--spacing-md)}.input-page__label{color:var(--color-text-secondary);margin-bottom:var(--spacing-xs);font-size:13px;font-weight:600;display:block}.input-page__cat-grid{gap:var(--spacing-sm);grid-template-columns:repeat(4,1fr);display:grid}.cat-btn{padding:var(--spacing-sm);border-radius:var(--radius-sm);background:var(--color-surface);min-height:var(--touch-min);transition:border-color var(--transition-fast);border:2px solid #0000;flex-direction:column;align-items:center;gap:4px;display:flex}.cat-btn--selected{border-color:var(--color-primary);background:var(--color-primary-light)}.cat-btn__icon{font-size:22px}.cat-btn__name{color:var(--color-text-secondary);text-align:center;font-size:10px}.input-page__text-input,.input-page__date-input{width:100%;height:var(--touch-comfortable);padding:0 var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);font-size:16px}.input-page__text-input:focus,.input-page__date-input:focus{border-color:var(--color-primary);outline:none}.input-page__submit{width:100%;height:var(--touch-comfortable);background:var(--color-primary);color:#fff;border-radius:var(--radius-md);margin-top:var(--spacing-sm);transition:opacity var(--transition-fast);font-size:16px;font-weight:600}.input-page__submit:disabled{opacity:.4}.input-page__role-warning{text-align:center;color:var(--color-warning);margin-top:var(--spacing-sm);font-size:13px}.input-page__approver-list{gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.input-page__diary-check{align-items:center;gap:var(--spacing-sm);min-height:var(--touch-min);color:var(--color-text);cursor:pointer;font-size:14px;font-weight:500;display:flex}.input-page__diary-check input[type=checkbox]{width:20px;height:20px;accent-color:var(--color-primary);cursor:pointer}.approver-btn{align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-full);background:var(--color-surface);border:2px solid var(--color-border);min-height:var(--touch-min);transition:all var(--transition-fast);display:flex}.approver-btn--selected{border-color:var(--color-primary);background:var(--color-primary-light)}.approver-btn__avatar{font-size:20px}.approver-btn__name{font-size:14px;font-weight:500}.input-page__no-approver{color:var(--color-warning);font-size:13px}.report-page{padding:var(--spacing-md);padding-top:calc(var(--spacing-md) + env(safe-area-inset-top,0px))}.report-page__header h1{margin-bottom:var(--spacing-md);font-size:20px;font-weight:700}.report-page__filters{gap:var(--spacing-sm);margin-bottom:var(--spacing-md);display:flex}.filter-chip{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-full);background:var(--color-surface);color:var(--color-text-secondary);box-shadow:var(--shadow-sm);min-height:36px;transition:all var(--transition-fast);font-size:13px;font-weight:600}.filter-chip--active{background:var(--color-primary);color:#fff}.report-page__summary{gap:var(--spacing-sm);margin-bottom:var(--spacing-md);display:flex}.report-page__summary-item{background:var(--color-surface);padding:var(--spacing-md);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);text-align:center;flex:1}.report-page__summary-label{color:var(--color-text-muted);margin-bottom:var(--spacing-xs);font-size:12px;display:block}.report-page__chart-section{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md);box-shadow:var(--shadow-sm)}.report-page__chart-title{margin-bottom:var(--spacing-sm);font-size:15px;font-weight:600}.report-page__breakdown{margin-bottom:var(--spacing-md)}.breakdown-group{border-bottom:1px solid var(--color-border)}.breakdown-group:last-child{border-bottom:none}.breakdown-row{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) 0;text-align:left;background:0 0;width:100%;display:flex}.breakdown-row--header{cursor:pointer}.breakdown-row--expanded{border-bottom:1px solid var(--color-border)}.breakdown-row__icon{flex-shrink:0;font-size:20px}.breakdown-row__name{flex:1;font-size:14px;font-weight:500}.breakdown-row__count{color:var(--color-text-muted);background:var(--color-bg);border-radius:var(--radius-full);padding:2px 8px;font-size:11px}.breakdown-row__total{color:var(--color-expense);font-variant-numeric:tabular-nums;font-size:14px;font-weight:600}.breakdown-row__arrow{color:var(--color-text-muted);transition:transform var(--transition-fast);flex-shrink:0;font-size:12px}.breakdown-row__arrow--open{transform:rotate(180deg)}.breakdown-detail{padding:var(--spacing-xs) 0 var(--spacing-sm) 28px}.breakdown-tx{padding:var(--spacing-xs) 0;border-bottom:1px dashed var(--color-border)}.breakdown-tx:last-child{border-bottom:none}.breakdown-tx__main{justify-content:space-between;align-items:center;gap:var(--spacing-sm);display:flex}.breakdown-tx__desc{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:13px;overflow:hidden}.breakdown-tx__amount{color:var(--color-expense);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:13px;font-weight:600}.breakdown-tx__meta{gap:var(--spacing-sm);color:var(--color-text-muted);flex-wrap:wrap;margin-top:2px;font-size:11px;display:flex}.settings-page{padding:var(--spacing-md);padding-top:calc(var(--spacing-md) + env(safe-area-inset-top,0px))}.settings-page__header h1{margin-bottom:var(--spacing-md);font-size:20px;font-weight:700}.settings-section{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md);box-shadow:var(--shadow-sm)}.settings-section--danger{border:1px solid var(--color-danger-light)}.settings-section__title{margin-bottom:var(--spacing-sm);font-size:15px;font-weight:600}.settings-section__desc{color:var(--color-text-muted);margin-bottom:var(--spacing-sm);font-size:12px}.settings-subsection-title{color:var(--color-text-secondary);margin-top:var(--spacing-sm);margin-bottom:var(--spacing-xs);font-size:13px;font-weight:600}.settings-user{gap:var(--spacing-sm);padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border);flex-direction:column;display:flex}.settings-user:last-of-type{border-bottom:none}.settings-user__info{align-items:center;gap:var(--spacing-sm);display:flex}.settings-user__avatar{font-size:24px}.settings-user__name{font-size:15px;font-weight:600}.settings-user__roles{gap:var(--spacing-xs);flex-wrap:wrap;display:flex}.role-chip{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border);min-height:32px;transition:all var(--transition-fast);font-size:12px;font-weight:600}.role-chip--active{background:var(--color-primary-light);color:var(--color-primary-dark);border-color:var(--color-primary)}.settings-cat-list{margin-bottom:var(--spacing-sm)}.settings-cat-item{padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;font-size:14px;display:flex}.settings-cat-item:last-child{border-bottom:none}.settings-cat-remove{background:var(--color-danger-light);width:32px;height:32px;color:var(--color-danger);border-radius:50%;justify-content:center;align-items:center;font-size:14px;display:flex}.settings-btn{width:100%;height:var(--touch-comfortable);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text);margin-top:var(--spacing-sm);font-size:15px;font-weight:600}.settings-btn--primary{background:var(--color-primary);color:#fff}.settings-btn--danger{background:var(--color-danger-light);color:var(--color-danger)}.add-cat-form{gap:var(--spacing-md);flex-direction:column;display:flex}.add-cat-form__type-toggle{background:var(--color-bg);border-radius:var(--radius-md);padding:3px;display:flex}.add-cat-form__input{width:100%;height:var(--touch-comfortable);padding:0 var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);font-size:16px}.add-cat-form__input:focus{border-color:var(--color-primary);outline:none}.add-cat-form__icons{gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.add-cat-form__icon-btn{border-radius:var(--radius-sm);background:var(--color-bg);border:2px solid #0000;justify-content:center;align-items:center;width:44px;height:44px;font-size:22px;display:flex}.add-cat-form__icon-btn--selected{border-color:var(--color-primary);background:var(--color-primary-light)}.settings-diary-list{flex-direction:column;gap:2px;display:flex}.settings-diary-item{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border);cursor:pointer;min-height:var(--touch-min);font-size:14px;display:flex}.settings-diary-item:last-child{border-bottom:none}.settings-diary-item input[type=checkbox]{width:20px;height:20px;accent-color:var(--color-primary);flex-shrink:0}.change-pin-form{gap:var(--spacing-md);flex-direction:column;display:flex}.settings-info{text-align:center;padding:var(--spacing-lg) 0;color:var(--color-text-muted);font-size:12px}.settings-info p{margin-bottom:2px}:root{--color-primary:#10b981;--color-primary-dark:#059669;--color-primary-light:#d1fae5;--color-danger:#ef4444;--color-danger-light:#fee2e2;--color-warning:#f59e0b;--color-warning-light:#fef3c7;--color-info:#3b82f6;--color-info-light:#dbeafe;--color-income:#10b981;--color-expense:#ef4444;--color-bg:#f8fafc;--color-surface:#fff;--color-border:#e2e8f0;--color-text:#1e293b;--color-text-secondary:#64748b;--color-text-muted:#94a3b8;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--touch-min:44px;--touch-comfortable:48px;--bottom-nav-height:56px;--safe-area-bottom:env(safe-area-inset-bottom,0px);--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 24px #0000001f;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.35s ease;--font-family:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html{-webkit-text-size-adjust:100%;touch-action:manipulation;font-size:16px}body{font-family:var(--font-family);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-user-select:none;user-select:none;overscroll-behavior-y:contain;line-height:1.5;overflow-x:hidden}#root{flex-direction:column;min-height:100dvh;display:flex}input,textarea,select,button{font-family:inherit;font-size:inherit}input[type=number]{font-size:16px}button{cursor:pointer;touch-action:manipulation;background:0 0;border:none}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}::-webkit-scrollbar{display:none}.scroll-hidden{-ms-overflow-style:none;scrollbar-width:none}.page-enter{animation:slideInRight var(--transition-normal) forwards}.page-exit{animation:slideOutLeft var(--transition-normal) forwards}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes slideOutLeft{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-30px)}}@keyframes sheetSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes sheetSlideDown{0%{transform:translateY(0)}to{transform:translateY(100%)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}.shake{animation:.5s shake}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{border-radius:var(--radius-sm);background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%) 0 0/200% 100%;animation:1.5s ease-in-out infinite shimmer}.pressable{transition:transform var(--transition-fast), opacity var(--transition-fast)}.pressable:active{opacity:.85;transform:scale(.97)}
