.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:100;background:#ffffffeb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(0,0,0,.06);padding-bottom:env(safe-area-inset-bottom,0px)}.bottom-nav__inner{display:flex;align-items:center;justify-content:space-around;height:72px;max-width:430px;margin:0 auto}.bottom-nav__item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 6px;background:none;border:none;border-radius:16px;cursor:pointer;position:relative;transition:all .2s ease;min-width:52px;flex:1}.bottom-nav__item:active{transform:scale(.92)}.bottom-nav__icon{font-size:20px;line-height:1;transition:transform .2s ease}.bottom-nav__item.active .bottom-nav__icon{transform:scale(1.15)}.bottom-nav__label{font-size:9px;font-weight:500;color:var(--text-muted);letter-spacing:.2px;transition:color .2s ease}.bottom-nav__item.active .bottom-nav__label{color:#7db8e8;font-weight:700}.bottom-nav__dot{position:absolute;bottom:4px;left:50%;transform:translate(-50%);width:4px;height:4px;border-radius:50%;background:#7db8e8;animation:scaleIn .2s ease both}.calorie-ring{position:relative;width:140px;height:140px;flex-shrink:0}.calorie-ring__bg{stroke:#e8f4fd}.calorie-ring__fill{stroke:url(#ringGradient);stroke:#7db8e8;transition:stroke-dasharray 1s cubic-bezier(.4,0,.2,1)}.calorie-ring svg{filter:drop-shadow(0 4px 12px rgba(125,184,232,.3))}.calorie-ring__center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;display:flex;flex-direction:column;align-items:center;gap:1px}.calorie-ring__value{font-size:22px;font-weight:800;color:var(--text-primary);line-height:1}.calorie-ring__label{font-size:10px;color:var(--text-muted);line-height:1.2}.calorie-ring__unit{font-size:11px;font-weight:600;color:#7db8e8}.macro-bar{display:flex;flex-direction:column;gap:6px;animation:fadeInUp .4s ease both}.macro-bar__header{display:flex;justify-content:space-between;align-items:center}.macro-bar__name{font-size:13px;font-weight:500;color:var(--text-secondary)}.macro-bar__value{font-size:13px;font-weight:700}.macro-bar__target{font-weight:400;color:var(--text-muted);font-size:11px}.macro-bar__track{height:6px;background:#f0ede8;border-radius:100px;overflow:hidden}.macro-bar__fill{height:100%;border-radius:100px;transition:width 1s cubic-bezier(.4,0,.2,1);opacity:.85}.home-page{display:flex;flex-direction:column;gap:14px}.home-header{display:flex;align-items:center;justify-content:space-between;padding:4px 0 8px}.home-header__greeting{font-size:22px;font-weight:800;color:var(--text-primary);line-height:1.2}.home-header__date{font-size:13px;color:var(--text-muted);margin-top:3px;text-transform:capitalize}.home-header__avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#7db8e8,#8fd4a3);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;box-shadow:0 4px 12px #7db8e866;flex-shrink:0}.home-badges{display:flex;gap:8px}.badge{flex:1;display:flex;align-items:center;gap:8px;padding:12px 10px;border-radius:var(--radius-sm);background:var(--bg-card);box-shadow:var(--shadow-sm)}.badge__icon{font-size:20px;line-height:1}.badge__info{display:flex;flex-direction:column;gap:1px}.badge__value{font-size:14px;font-weight:700;color:var(--text-primary);line-height:1}.badge__label{font-size:10px;color:var(--text-muted);line-height:1.3}.home-calorie-card{display:flex;gap:16px;align-items:center;padding:20px}.home-calorie-card__right{flex:1;display:flex;flex-direction:column;gap:8px}.home-calorie-card__title{font-size:15px;font-weight:700;color:var(--text-primary)}.home-calorie-card__progress-bar{height:6px;background:#f0ede8;border-radius:100px;overflow:hidden}.home-calorie-card__progress-fill{height:100%;background:linear-gradient(90deg,#7db8e8,#8fd4a3);border-radius:100px;transition:width 1s cubic-bezier(.4,0,.2,1)}.home-calorie-card__remain{font-size:12px;color:var(--text-secondary)}.home-calorie-card__remain strong{color:var(--text-primary)}.home-calorie-card__macros{display:flex;flex-direction:column;gap:8px}.home-xp{display:flex;flex-direction:column;gap:10px}.home-xp__header{display:flex;justify-content:space-between;align-items:center}.home-xp__label{font-size:14px;font-weight:600;color:var(--text-primary)}.home-xp__level{font-size:13px;font-weight:700;color:#b8a8e8;background:#f0ecf9;padding:3px 10px;border-radius:100px}.home-xp__bar-track{height:8px;background:#f0ede8;border-radius:100px;overflow:hidden}.home-xp__bar-fill{height:100%;background:linear-gradient(90deg,#b8a8e8,#7db8e8);border-radius:100px;transition:width 1.2s cubic-bezier(.4,0,.2,1)}.home-xp__footer{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted)}.home-water{display:flex;flex-direction:column;gap:12px}.home-water__header{display:flex;justify-content:space-between;align-items:center}.home-water__title{font-size:14px;font-weight:600;color:var(--text-primary)}.home-water__value{font-size:13px;font-weight:700;color:#7db8e8}.home-water__cups{display:flex;gap:6px;flex-wrap:wrap}.home-water__cup{font-size:20px;opacity:.2;cursor:pointer;transition:all .2s ease}.home-water__cup.filled{opacity:1;transform:scale(1.05)}@keyframes gold-shimmer{0%{background-position:-200% center}to{background-position:200% center}}.home-subscribe-btn{position:relative;overflow:hidden;background:linear-gradient(105deg,#c8860a,#ffd060 30%,#ffa820,#ffd060 70%,#c8860a);background-size:200% auto;animation:gold-shimmer 12s linear infinite;color:#fff;font-size:11px;font-weight:800;letter-spacing:1px;padding:6px 12px;border-radius:100px;border:none;cursor:pointer;box-shadow:0 3px 10px #c8860a66;text-shadow:0 1px 2px rgba(0,0,0,.2);transition:transform .15s ease,box-shadow .15s ease;white-space:nowrap;text-align:center}.home-subscribe-btn:active{transform:scale(.95);box-shadow:0 2px 6px #c8860a40}.home-header__premium-btn{background:linear-gradient(135deg,#ffd485,#ffa040);color:#fff;font-size:12px;font-weight:700;padding:7px 14px;border-radius:100px;border:none;cursor:pointer;box-shadow:0 4px 12px #ffa04059;transition:all .2s ease;white-space:nowrap}.home-header__premium-btn:active{transform:scale(.95)}.home-chat-banner{display:flex;align-items:center;gap:16px;padding:18px 20px;background:linear-gradient(135deg,#7c3aed21,#3b82f621);border-radius:var(--radius-md);border:2px solid rgba(124,58,237,.3);cursor:pointer;transition:all .2s ease;width:100%;text-align:left;position:relative;overflow:hidden}.home-chat-banner:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(124,58,237,.06),transparent);transform:translate(-100%);animation:chat-shimmer 3s infinite}@keyframes chat-shimmer{0%{transform:translate(-100%)}60%{transform:translate(100%)}to{transform:translate(100%)}}.home-chat-banner:active{transform:scale(.98)}.home-chat-banner__orb{position:relative;width:68px;height:68px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.home-chat-orb-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:conic-gradient(from 0deg,#7c3aed,#3b82f6,#06b6d4,#7c3aed);animation:chat-orb-spin 2.5s linear infinite}.home-chat-orb-ring--2{top:5px;right:5px;bottom:5px;left:5px;background:var(--surface, #fff);animation:none}@keyframes chat-orb-spin{to{transform:rotate(360deg)}}.home-chat-orb-video{position:relative;z-index:1;width:58px;height:58px;border-radius:50%;object-fit:cover;pointer-events:none}.home-chat-banner__text{flex:1;min-width:0}.home-chat-banner__title{font-size:17px;font-weight:700;color:var(--text-primary);margin:0 0 4px;display:flex;align-items:center;gap:7px}.home-chat-ai-badge{font-size:10px;font-weight:800;letter-spacing:.5px;background:linear-gradient(135deg,#7c3aed,#3b82f6);color:#fff;padding:1px 6px;border-radius:100px}.home-chat-banner__desc{font-size:13px;color:var(--text-muted);margin:0}.home-chat-banner__arrow{font-size:22px;color:var(--text-muted);flex-shrink:0}.home-game-banner{display:flex;align-items:center;gap:12px;padding:14px 16px;background:linear-gradient(135deg,#c960401a,#ffb4641f);border-radius:var(--radius-md);border:1.5px solid rgba(201,96,64,.22);cursor:pointer;transition:all .2s ease;width:100%;text-align:left}.home-game-banner:active{transform:scale(.98)}.home-game-banner__left{display:flex;align-items:center;gap:12px;flex:1}.home-game-banner__video-wrap{width:48px;height:48px;border-radius:50%;overflow:hidden;flex-shrink:0}.home-game-banner__video{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block;pointer-events:none}.home-game-banner__title{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:2px}.home-game-banner__desc{font-size:12px;color:var(--text-secondary);margin:0}.home-game-banner__arrow{font-size:16px;color:#c96040}.home-premium-banner{display:flex;align-items:center;gap:12px;padding:14px 16px;background:linear-gradient(135deg,#7db8e81f,#8fd4a31f);border-radius:var(--radius-md);border:1.5px solid rgba(125,184,232,.25);cursor:pointer;transition:all .2s ease}.home-premium-banner:active{transform:scale(.98)}.home-premium-banner__left{flex:1}.home-premium-banner__title{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:2px}.home-premium-banner__desc{font-size:12px;color:var(--text-secondary)}.home-premium-banner__arrow{font-size:22px;color:var(--color-blue);font-weight:300}.home-trial-banner{display:flex;align-items:center;gap:12px;padding:14px 16px;background:linear-gradient(135deg,#8fd4a326,#f4a8b51f);border-radius:var(--radius-md);border:1.5px solid rgba(143,212,163,.4);cursor:pointer;transition:all .2s ease}.home-trial-banner:active{transform:scale(.98)}.home-trial-banner__left{flex:1}.home-trial-banner__title{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:2px}.home-trial-banner__desc{font-size:12px;color:var(--text-secondary)}.home-trial-banner__arrow{font-size:22px;color:var(--color-green);font-weight:300}.home-motivation__card{background:linear-gradient(135deg,#f4a8b5,#b8a8e8,#7db8e8);border-radius:var(--radius-md);padding:20px;text-align:center;box-shadow:0 8px 24px #7db8e840}.home-motivation__text{font-size:15px;font-weight:500;color:#fff;line-height:1.6;font-style:italic}.home-motivation__author{display:block;margin-top:10px;font-size:12px;font-weight:700;color:#fffc;letter-spacing:.5px}.meal-item{background:var(--bg-card);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow .2s ease}.meal-item--expanded{box-shadow:var(--shadow-md)}.meal-item__row{display:flex;align-items:center;gap:12px;padding:14px;cursor:pointer;transition:background .15s ease}.meal-item__row:active{background:var(--bg-card-soft)}.meal-item__icon{font-size:28px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--bg);border-radius:12px;flex-shrink:0}.meal-item__info{flex:1;display:flex;flex-direction:column;gap:3px}.meal-item__name{font-size:14px;font-weight:600;color:var(--text-primary);line-height:1.3}.meal-item__time{font-size:12px;color:var(--text-muted)}.meal-item__macros{display:flex;gap:6px;margin-top:4px}.meal-item__macro{font-size:11px;font-weight:600;padding:2px 7px;border-radius:100px}.meal-item__macro--blue{background:var(--color-blue-light);color:#5a9fd4}.meal-item__macro--pink{background:var(--color-pink-light);color:#d4798a}.meal-item__macro--green{background:var(--color-green-light);color:#5a9e73}.meal-item__right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}.meal-item__cal{display:flex;flex-direction:column;align-items:flex-end}.meal-item__cal-value{font-size:18px;font-weight:800;color:var(--text-primary);line-height:1}.meal-item__cal-unit{font-size:10px;color:var(--text-muted)}.meal-item__chevron{font-size:18px;color:var(--text-muted);transition:transform .25s ease;line-height:1;display:block}.meal-item__chevron.open{transform:rotate(90deg)}.meal-detail{padding:0 14px 14px;animation:fadeInUp .25s ease both;border-top:1px solid rgba(0,0,0,.05)}.meal-detail__section-title{font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:12px 0 8px}.meal-detail__list{list-style:none;display:flex;flex-direction:column;gap:6px}.meal-detail__item{display:flex;justify-content:space-between;align-items:center;padding:7px 10px;background:var(--bg);border-radius:8px}.meal-detail__item-name{font-size:13px;color:var(--text-primary)}.meal-detail__item-amount{font-size:13px;font-weight:700;color:var(--color-blue)}.meal-detail__recipe{margin-top:4px}.meal-detail__recipe-text{font-size:13px;color:var(--text-secondary);line-height:1.6;background:var(--bg);padding:10px 12px;border-radius:8px}.meal-detail__replace{width:100%;margin-top:12px;padding:10px;border-radius:var(--radius-sm);background:var(--bg);border:1.5px dashed var(--color-blue);color:var(--color-blue);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.meal-detail__replace:active{background:var(--color-blue-light)}.meal-item__check{width:26px;height:26px;min-width:26px;border-radius:50%;border:2px solid #C8D8E8;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.meal-item__check--done{background:#5a9e73;border-color:#5a9e73}.meal-item--checked{opacity:.72}.meal-item--checked .meal-item__name{text-decoration:line-through;color:var(--text-muted)}.nutrition-page{display:flex;flex-direction:column;gap:16px}.day-tabs{display:flex;gap:8px}.day-tab{flex:1;padding:8px 4px;border-radius:10px;border:1px solid #EDE8E3;background:#fff;font-size:13px;font-weight:500;color:#888;cursor:pointer;transition:all .2s}.day-tab--active{background:linear-gradient(135deg,#7db8e8,#5bc8c0);color:#fff;border-color:transparent;font-weight:700}.nutrition-header{display:flex;justify-content:space-between;align-items:center}.nutrition-header__date{font-size:13px;color:var(--text-muted);font-weight:500}.nutrition-total{display:flex;flex-direction:column;gap:12px;padding:20px}.nutrition-total__header{display:flex;justify-content:space-between;align-items:center}.nutrition-total__label{font-size:14px;color:var(--text-secondary);font-weight:500}.nutrition-total__kcal{font-size:28px;font-weight:800;color:var(--text-primary);line-height:1}.nutrition-total__kcal span{font-size:14px;font-weight:500;color:var(--text-muted)}.nutrition-total__bar-track{height:8px;background:#f0ede8;border-radius:100px;overflow:hidden}.nutrition-total__bar-fill{height:100%;background:linear-gradient(90deg,#7db8e8,#8fd4a3);border-radius:100px;transition:width 1s cubic-bezier(.4,0,.2,1)}.nutrition-total__remain{font-size:12px;color:var(--text-secondary)}.nutrition-total__remain strong{color:var(--text-primary);font-weight:700}.nutrition-total__macros{display:flex;align-items:center;justify-content:space-around;padding-top:4px}.nutrition-total__macro{display:flex;flex-direction:column;align-items:center;gap:2px}.nutrition-total__macro-value{font-size:18px;font-weight:800}.nutrition-total__macro-label{font-size:11px;color:var(--text-muted)}.macro--blue .nutrition-total__macro-value{color:#7db8e8}.macro--pink .nutrition-total__macro-value{color:#f4a8b5}.macro--green .nutrition-total__macro-value{color:#8fd4a3}.nutrition-total__divider{width:1px;height:32px;background:#f0ede8}.nutrition-meals,.nutrition-ai{display:flex;flex-direction:column;gap:10px}.nutrition-ai__item{display:flex;gap:12px;padding:14px;border-radius:var(--radius-sm);animation:fadeInUp .4s ease both}.ai-motivation{background:linear-gradient(135deg,#7db8e81f,#8fd4a31f);border-left:3px solid #7DB8E8}.ai-tip{background:#8fd4a31f;border-left:3px solid #8FD4A3}.ai-warning{background:#ffd48526;border-left:3px solid #FFD485}.nutrition-ai__icon{font-size:20px;flex-shrink:0}.nutrition-ai__text{font-size:13px;color:var(--text-secondary);line-height:1.5}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:200;display:flex;align-items:flex-end;animation:fadeInUp .2s ease}.modal{width:100%;background:#fff;border-radius:24px 24px 0 0;padding:24px 20px calc(24px + env(safe-area-inset-bottom,0px));animation:scaleIn .25s ease;display:flex;flex-direction:column;gap:16px}.modal__header{display:flex;justify-content:space-between;align-items:center}.modal__header h3{font-size:18px;font-weight:700}.modal__close{width:32px;height:32px;border-radius:50%;background:#f0ede8;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--text-secondary);cursor:pointer}.modal__desc{font-size:14px;color:var(--text-secondary);line-height:1.5}.modal__quick-title{font-size:13px;font-weight:600;color:var(--text-muted);margin-bottom:8px}.modal__quick{display:flex;flex-direction:column;gap:8px}.modal__quick-item{padding:13px 16px;background:var(--bg);border-radius:var(--radius-sm);font-size:14px;font-weight:500;color:var(--text-primary);text-align:left;cursor:pointer;transition:all .15s ease}.modal__quick-item:active{transform:scale(.98);background:#edebe6}.xp-popup{position:fixed;top:40px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#b8a8e8,#7db8e8);color:#fff;font-size:16px;font-weight:700;padding:12px 24px;border-radius:100px;z-index:500;box-shadow:0 8px 24px #7db8e866;animation:scaleIn .3s ease,fadeOutUp .5s ease 2.5s both}@keyframes fadeOutUp{to{opacity:0;transform:translate(-50%) translateY(-10px)}}.exercise-item{background:var(--bg-card);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow .2s ease}.exercise-item.expanded{box-shadow:var(--shadow-md)}.exercise-item__row{display:flex;align-items:center;gap:12px;padding:14px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s ease}.exercise-item__row:active{background:var(--bg-card-soft)}.exercise-item.completed{opacity:.7}.exercise-item.completed .exercise-item__name{text-decoration:line-through;color:var(--text-muted)}.exercise-item__check{width:28px;height:28px;border-radius:8px;border:2px solid #E0DDD8;background:none;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .2s ease;cursor:pointer}.exercise-item__check.checked{background:linear-gradient(135deg,#7db8e8,#8fd4a3);border-color:transparent;animation:checkmark .2s ease both}.exercise-item__info{flex:1;display:flex;flex-direction:column;gap:6px}.exercise-item__name{font-size:14px;font-weight:600;color:var(--text-primary);transition:all .2s ease}.exercise-item__meta{display:flex;align-items:center;gap:8px}.exercise-item__muscle{font-size:11px;font-weight:600;padding:3px 8px;border-radius:100px}.exercise-item__sets{font-size:12px;color:var(--text-muted)}.exercise-item__info-btn{width:28px;height:28px;border-radius:50%;border:none;background:var(--bg);color:var(--text-muted);font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;transition:all .2s ease}.exercise-item__info-btn.active{background:var(--color-blue-light);color:var(--color-blue)}.exercise-item__technique{padding:0 14px 14px;border-top:1px solid rgba(0,0,0,.05);animation:fadeInUp .25s ease both}.exercise-item__technique-label{font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:12px 0 8px}.exercise-item__technique-text{font-size:13px;color:var(--text-secondary);line-height:1.65;background:var(--bg);padding:10px 12px;border-radius:8px;border-left:3px solid var(--color-blue)}.exercise-item__detail{padding:0 14px 14px;border-top:1px solid rgba(0,0,0,.05);animation:fadeInUp .25s ease both}.exercise-item__gif-wrap{display:flex;justify-content:center;padding:14px 0 4px}.exercise-item__gif{width:100%;max-width:280px;height:160px;object-fit:contain;border-radius:10px;background:var(--bg)}.muscle-map{display:flex;gap:16px;justify-content:center;padding:14px 0 4px}.muscle-map__view{display:flex;flex-direction:column;align-items:center;gap:4px}.muscle-map__label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;margin:0}.workout-page{display:flex;flex-direction:column;gap:16px}.workout-header{display:flex;justify-content:space-between;align-items:center}.workout-header__day{font-size:13px;color:var(--text-muted);margin-top:2px}.workout-header__tag{background:linear-gradient(135deg,#7db8e8,#8fd4a3);color:#fff;font-size:12px;font-weight:700;padding:6px 14px;border-radius:100px;letter-spacing:.3px}.workout-progress{display:flex;flex-direction:column;gap:12px;padding:20px}.workout-progress__header{display:flex;justify-content:space-between;align-items:center}.workout-progress__label{font-size:14px;color:var(--text-secondary);font-weight:500}.workout-progress__count{font-size:18px;font-weight:800;color:var(--text-primary)}.workout-progress__track{height:10px;background:#f0ede8;border-radius:100px;overflow:hidden}.workout-progress__fill{height:100%;background:linear-gradient(90deg,#8fd4a3,#7db8e8);border-radius:100px;transition:width .6s cubic-bezier(.4,0,.2,1)}.workout-progress__stats{display:flex;justify-content:space-around;padding-top:4px}.workout-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.workout-stat__value{font-size:20px;font-weight:800;color:var(--text-primary);line-height:1}.workout-stat__label{font-size:11px;color:var(--text-muted)}.workout-exercises{display:flex;flex-direction:column;gap:10px}.btn--disabled{opacity:.5;pointer-events:none}.workout-done{display:flex;align-items:center;gap:14px;padding:20px;background:linear-gradient(135deg,#8fd4a333,#7db8e833);border-radius:var(--radius-md);border:1px solid rgba(143,212,163,.4)}.workout-done__icon{font-size:36px}.workout-done__title{font-size:16px;font-weight:700;color:var(--text-primary)}.workout-done__sub{font-size:14px;color:#8fd4a3;font-weight:600;margin-top:3px}.xp-popup{position:fixed;top:40px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#b8a8e8,#7db8e8);color:#fff;font-size:16px;font-weight:700;padding:12px 24px;border-radius:100px;z-index:500;box-shadow:0 8px 24px #7db8e866;animation:scaleIn .3s ease,fadeOut .5s ease 2.5s both}@keyframes fadeOut{to{opacity:0;transform:translate(-50%) translateY(-10px)}}.week-days{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px}.week-day{flex:1;min-width:36px;display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 4px;border-radius:10px;border:1px solid #EDE8E3;background:#fff;cursor:pointer;transition:all .2s;font-size:11px}.week-day--active{background:linear-gradient(135deg,#7db8e8,#5bc8c0);color:#fff;border-color:transparent}.week-day--rest{opacity:.5}.week-day__label{font-weight:700;font-size:11px}.week-day__dot{font-size:13px}.workout-type-toggle{display:flex;gap:6px}.type-btn{padding:6px 12px;border-radius:20px;border:1px solid #EDE8E3;background:#fff;font-size:12px;cursor:pointer;transition:all .2s;white-space:nowrap}.type-btn--active{background:linear-gradient(135deg,#7db8e8,#5bc8c0);color:#fff;border-color:transparent}.workout-rest{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center}.workout-tip{padding:14px}.workout-tip__text{font-size:13px;color:var(--text-secondary);line-height:1.6}.progress-page{display:flex;flex-direction:column;gap:16px}.progress-header{display:flex;justify-content:space-between;align-items:center}.progress-header__period{display:flex;gap:4px;background:#f0ede8;padding:3px;border-radius:10px}.period-btn{padding:6px 14px;border-radius:8px;font-size:13px;font-weight:600;color:var(--text-muted);background:none;cursor:pointer;transition:all .2s ease}.period-btn.active{background:#fff;color:var(--text-primary);box-shadow:0 2px 6px #00000014}.progress-goal{display:flex;flex-direction:column;gap:10px;padding:20px}.progress-goal__header{display:flex;justify-content:space-between;align-items:flex-start}.progress-goal__label{font-size:13px;color:var(--text-muted)}.progress-goal__target{font-size:24px;font-weight:800;color:var(--text-primary)}.progress-goal__right{text-align:right}.progress-goal__lost{display:block;font-size:22px;font-weight:800;color:#8fd4a3;line-height:1}.progress-goal__lost-label{font-size:11px;color:var(--text-muted)}.progress-goal__bar-track{height:10px;background:#f0ede8;border-radius:100px;overflow:hidden}.progress-goal__bar-fill{height:100%;background:linear-gradient(90deg,#7db8e8,#8fd4a3);border-radius:100px;transition:width 1.2s cubic-bezier(.4,0,.2,1)}.progress-goal__footer{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted)}.progress-goal__pct{font-weight:700;color:#7db8e8;font-size:13px}.progress-goal__remain{font-size:13px;color:var(--text-secondary);text-align:center;background:#f7f4f0;padding:10px;border-radius:10px}.progress-goal__remain strong{color:var(--text-primary)}.progress-chart{padding:20px;display:flex;flex-direction:column;gap:12px}.progress-chart__header{display:flex;justify-content:space-between;align-items:center}.progress-chart__title{font-size:15px;font-weight:700;color:var(--text-primary)}.progress-chart__diff{font-size:15px;font-weight:700;padding:4px 12px;border-radius:100px}.progress-chart__diff.down{background:#8fd4a326;color:#5a9e73}.progress-chart__diff.up{background:#f4a8b526;color:#d4798a}.chart-tooltip{background:#fff;padding:8px 12px;border-radius:10px;box-shadow:0 4px 12px #0000001f;display:flex;flex-direction:column;gap:2px}.chart-tooltip__label{font-size:11px;color:var(--text-muted)}.chart-tooltip__value{font-size:14px;font-weight:700;color:var(--text-primary)}.progress-chart__legend{font-size:12px;color:var(--text-muted);display:flex;align-items:center;gap:6px}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.legend-dot--green{background:#8fd4a3}.progress-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.progress-stat-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 12px;text-align:center}.progress-stat-card__icon{font-size:24px}.progress-stat-card__value{font-size:22px;font-weight:800;color:var(--text-primary);line-height:1}.progress-stat-card__label{font-size:11px;color:var(--text-muted);line-height:1.3}.progress-achievements{display:flex;flex-direction:column;gap:10px}.achievement-item{display:flex;align-items:center;gap:14px;padding:14px}.achievement-item.locked{opacity:.45}.achievement-item__icon{font-size:28px;flex-shrink:0}.achievement-item__info{flex:1}.achievement-item__title{font-size:14px;font-weight:700;color:var(--text-primary)}.achievement-item__desc{font-size:12px;color:var(--text-muted);margin-top:2px}.achievement-item__check{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#7db8e8,#8fd4a3);color:#fff;font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.achievement-item__lock{font-size:18px;flex-shrink:0}.rating-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.rating-header__week{font-size:13px;font-weight:500;color:var(--text-muted);background:var(--bg-card);padding:4px 12px;border-radius:100px;box-shadow:var(--shadow-sm)}.rating-league-card{border-radius:var(--radius-md);padding:18px;border:1.5px solid transparent;margin-bottom:20px;box-shadow:var(--shadow-sm)}.rating-league-card__top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}.rating-league-card__label{font-size:12px;color:var(--text-muted);margin-bottom:2px}.rating-league-card__name{font-size:22px;font-weight:800}.rating-league-card__rank{display:flex;flex-direction:column;align-items:flex-end}.rating-league-card__rank-num{font-size:26px;font-weight:800;color:var(--text-primary);line-height:1}.rating-league-card__rank-label{font-size:11px;color:var(--text-muted)}.rating-league-card__bar-track{height:8px;background:#00000014;border-radius:100px;margin-bottom:6px;overflow:hidden}.rating-league-card__bar-fill{height:100%;border-radius:100px;transition:width .6s ease}.rating-league-card__bar-footer{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted);margin-bottom:16px}.rating-league-card__stats{display:flex;gap:0}.rating-league-stat{flex:1;display:flex;flex-direction:column;align-items:center;padding:10px 0;background:#fff9;border-radius:var(--radius-sm)}.rating-league-stat:not(:last-child){margin-right:8px}.rating-league-stat__val{font-size:20px;font-weight:800;line-height:1.2}.rating-league-stat__lbl{font-size:10px;color:var(--text-muted);margin-top:2px}.rating-podium{display:flex;align-items:flex-end;justify-content:center;gap:8px;margin-bottom:20px}.podium-item{display:flex;flex-direction:column;align-items:center;flex:1}.podium-crown{font-size:20px;margin-bottom:2px}.podium-avatar{width:44px;height:44px;border-radius:50%;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.podium-avatar--1{width:52px;height:52px;background:linear-gradient(135deg,gold,orange);color:#fff;font-size:18px;box-shadow:0 4px 12px #ffd70066}.podium-name{font-size:11px;font-weight:600;color:var(--text-primary);margin-bottom:2px;text-align:center}.podium-xp{font-size:10px;color:var(--text-muted);margin-bottom:4px}.podium-block{width:100%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:#fff;border-radius:12px 12px 0 0}.podium-block--1{height:80px;background:linear-gradient(180deg,gold,orange)}.podium-block--2{height:60px;background:linear-gradient(180deg,#b0b0b0,#888)}.podium-block--3{height:44px;background:linear-gradient(180deg,#cd7f32,#a0601a)}.rating-list{display:flex;flex-direction:column;gap:8px}.rating-row{display:flex;align-items:center;gap:10px;padding:12px 14px;animation:fadeInUp .4s ease both}.rating-row--current{border:1.5px solid var(--color-blue);box-shadow:0 2px 12px #7db8e833}.rating-row__rank{font-size:13px;font-weight:700;color:var(--text-muted);width:28px;flex-shrink:0}.rating-row__avatar{width:36px;height:36px;border-radius:50%;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--text-secondary);flex-shrink:0}.rating-row__info{flex:1;display:flex;flex-direction:column;gap:2px}.rating-row__name{font-size:14px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:6px}.rating-row__you{font-size:10px;font-weight:700;background:var(--color-blue-light);color:#5a9fd4;padding:1px 7px;border-radius:100px}.rating-row__streak{font-size:11px;color:var(--text-muted)}.rating-row__xp{display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0}.rating-row__xp-val{font-size:15px;font-weight:800;color:var(--text-primary)}.rating-row__xp-lbl{font-size:10px;color:var(--text-muted)}.rating-reset{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--bg-card-soft);border-radius:var(--radius-sm);margin-top:4px;margin-bottom:8px}.rating-reset__icon{font-size:18px;flex-shrink:0}.rating-reset__text{font-size:12px;color:var(--text-muted);line-height:1.4}.sub-page{padding-top:12px;display:flex;flex-direction:column;gap:14px}.sub-back{background:none;border:none;font-size:14px;font-weight:600;color:var(--text-secondary);padding:0;cursor:pointer;align-self:flex-start}.sub-active-banner{display:flex;align-items:center;justify-content:space-between;gap:8px;background:linear-gradient(135deg,#7c3aed1a,#3b82f61a);border:1.5px solid rgba(124,58,237,.25);border-radius:var(--radius-sm);padding:12px 16px}.sub-active-banner__label{font-size:14px;font-weight:700;color:#7c3aed}.sub-active-banner__expires{font-size:13px;color:var(--text-secondary)}.sub-active-banner__expires strong{color:var(--text-primary)}.sub-trial-badge{background:linear-gradient(135deg,#8fd4a326,#7db8e826);border:1.5px solid rgba(143,212,163,.4);border-radius:var(--radius-sm);padding:12px 14px;font-size:13px;color:var(--text-secondary);line-height:1.5;text-align:center}.sub-trial-badge strong{color:#5a9e73}.sub-hero{text-align:center;padding:4px 0 8px}.sub-hero__pill{display:inline-block;background:linear-gradient(135deg,#7db8e8,#8fd4a3);color:#fff;font-size:12px;font-weight:700;padding:5px 16px;border-radius:100px;margin-bottom:12px;letter-spacing:.3px}.sub-hero__title{font-size:26px;font-weight:800;color:var(--text-primary);line-height:1.25;margin-bottom:8px}.sub-hero__desc{font-size:13px;color:var(--text-secondary)}.sub-tariffs{display:flex;flex-direction:column;gap:10px}.sub-tariff{position:relative;width:100%;padding:14px 16px;background:var(--bg-card);border-radius:var(--radius-md);border:2px solid transparent;box-shadow:var(--shadow-sm);text-align:left;cursor:pointer;transition:all .2s ease}.sub-tariff--active{border-color:var(--color-blue);box-shadow:0 4px 16px #7db8e833}.sub-tariff--highlight.sub-tariff--active{border-color:gold;box-shadow:0 4px 16px #ffd70033}.sub-tariff:active{transform:scale(.98)}.sub-tariff__badge{position:absolute;top:-11px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#ffd485,#ffa040);color:#fff;font-size:11px;font-weight:700;padding:3px 12px;border-radius:100px;white-space:nowrap}.sub-tariff__top{display:flex;align-items:center;gap:10px}.sub-tariff__radio{width:20px;height:20px;border-radius:50%;border:2px solid #D0CDCA;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .2s}.sub-tariff--active .sub-tariff__radio{border-color:var(--color-blue)}.sub-tariff--highlight.sub-tariff--active .sub-tariff__radio{border-color:gold}.sub-tariff__dot{width:10px;height:10px;border-radius:50%;background:transparent;transition:background .2s}.sub-tariff__dot.active{background:var(--color-blue)}.sub-tariff--highlight .sub-tariff__dot.active{background:gold}.sub-tariff__emoji{font-size:20px;flex-shrink:0}.sub-tariff__label{font-size:16px;font-weight:700;color:var(--text-primary);flex:1}.sub-tariff__price-wrap{text-align:right;flex-shrink:0}.sub-tariff__price{display:block;font-size:17px;font-weight:800;color:var(--text-primary);line-height:1.1}.sub-tariff__period{font-size:10px;color:var(--text-muted)}.sub-tariff__economy{margin-top:6px;margin-left:30px;font-size:11px;color:#5a9e73;font-weight:600}.sub-features-card{background:var(--bg-card);border-radius:var(--radius-md);padding:14px 16px;box-shadow:var(--shadow-sm)}.sub-features-card__title{font-size:13px;font-weight:700;color:var(--text-primary);margin-bottom:10px}.sub-feature-row{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid rgba(0,0,0,.04)}.sub-feature-row:last-child{border-bottom:none}.sub-feature-row__check{font-size:13px;font-weight:700;color:var(--color-green);flex-shrink:0;width:20px}.sub-feature-row__text{font-size:13px;color:var(--text-primary)}.sub-cta{width:100%;padding:17px;border-radius:var(--radius-md);font-size:16px;font-weight:700;color:#fff;background:linear-gradient(135deg,#7db8e8,#8fd4a3);box-shadow:0 6px 20px #7db8e866;display:flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;transition:all .2s ease}.sub-cta:active{transform:scale(.97);box-shadow:0 3px 10px #7db8e84d}.sub-cta-hint{text-align:center;font-size:12px;color:var(--text-muted);margin-top:-6px}.sub-polling-hint{text-align:center;font-size:12px;color:var(--color-blue);margin-top:-8px;line-height:1.4}.sub-paid-banner{background:linear-gradient(135deg,#8fd4a333,#7db8e826);border:1.5px solid rgba(143,212,163,.5);border-radius:var(--radius-md);padding:18px 16px;text-align:center;display:flex;flex-direction:column;gap:12px;align-items:center}.sub-paid-banner__text{font-size:15px;font-weight:700;color:var(--text-primary)}.sub-free{background:var(--bg-card-soft);border-radius:var(--radius-md);padding:14px 16px}.sub-free__title{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.sub-free-item{display:flex;align-items:center;gap:10px;padding:6px 0}.sub-free-item__icon{font-size:18px;width:28px;flex-shrink:0;text-align:center}.sub-free-item__label{font-size:13px;font-weight:600;color:var(--text-secondary)}.sub-free-item__desc{font-size:11px;color:var(--text-muted)}.sub-guarantee{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.sub-guarantee__icon{font-size:28px;flex-shrink:0}.sub-guarantee__title{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:2px}.sub-guarantee__desc{font-size:12px;color:var(--text-muted)}.sub-legal{font-size:11px;color:var(--text-muted);text-align:center;line-height:1.6;padding-bottom:8px}.promo-section{margin:8px 16px 0}.promo-toggle{width:100%;background:none;border:1.5px dashed #C4B5FD;border-radius:14px;padding:13px 18px;font-size:15px;font-weight:600;color:#7c3aed;cursor:pointer;text-align:center;transition:background .15s}.promo-toggle:active{background:#7c3aed0f}.promo-body{padding:12px 0 4px;display:flex;flex-direction:column;gap:8px}.promo-input-row{display:flex;gap:8px}.promo-input{flex:1;padding:12px 14px;border:1.5px solid #EDE8E3;border-radius:12px;font-size:15px;font-weight:700;letter-spacing:.04em;background:#fff;outline:none;color:#1a1a1a;transition:border-color .15s}.promo-input:focus{border-color:#7c3aed}.promo-apply-btn{padding:12px 18px;background:#7c3aed;color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;white-space:nowrap;transition:opacity .15s}.promo-apply-btn:disabled{opacity:.45;cursor:not-allowed}.promo-result{font-size:14px;font-weight:600;margin:0;padding:10px 14px;border-radius:10px;line-height:1.4}.promo-result--ok{background:#ecfdf5;color:#065f46}.promo-result--err{background:#fef2f2;color:#991b1b}.referral-section{margin:8px 16px 0;background:linear-gradient(135deg,#f5f3ff,#ede9fe);border-radius:18px;padding:18px 16px}.referral-section__title{font-size:16px;font-weight:700;color:#1a1a1a;margin:0 0 4px}.referral-section__desc{font-size:13px;color:#6b7280;margin:0 0 14px;line-height:1.45}.referral-link-row{display:flex;gap:8px;align-items:center;background:#fff;border-radius:12px;padding:10px 12px;margin-bottom:12px;border:1.5px solid #DDD6FE}.referral-link-text{flex:1;font-size:13px;font-weight:600;color:#7c3aed;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.referral-copy-btn{flex-shrink:0;background:#7c3aed;color:#fff;border:none;border-radius:9px;padding:7px 13px;font-size:13px;font-weight:700;cursor:pointer;transition:opacity .15s}.referral-copy-btn:active{opacity:.75}.referral-stats{display:flex;gap:10px}.referral-stat{flex:1;background:#fff;border-radius:12px;padding:10px 12px;text-align:center;border:1px solid #EDE9FE}.referral-stat__val{font-size:22px;font-weight:800;color:#7c3aed;display:block}.referral-stat__label{font-size:11px;color:#6b7280;display:block;margin-top:2px;line-height:1.3}.referral-copied-hint{font-size:13px;color:#059669;font-weight:600;text-align:center;margin:6px 0 0}.setup-page{min-height:100vh;background:var(--cream, #F5F0EB);padding:24px 20px 40px;display:flex;flex-direction:column;align-items:center}.setup-progress{width:100%;display:flex;align-items:center;gap:10px;margin-bottom:24px}.setup-progress__bar{flex:1;height:6px;background:#ede8e3;border-radius:3px;overflow:hidden}.setup-progress__fill{height:100%;background:linear-gradient(90deg,#7db8e8,#8fd4a3);border-radius:3px;transition:width .4s ease}.setup-progress__label{font-size:12px;color:#999;white-space:nowrap}.setup-logo{font-size:28px;font-weight:900;background:linear-gradient(135deg,#7db8e8,#5bc8c0,#f08090);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px}.setup-step-label{font-size:13px;color:#999;text-transform:uppercase;letter-spacing:1px;margin-bottom:24px}.setup-q{font-size:22px;font-weight:700;color:#2d2d2d;text-align:center;margin-bottom:24px;line-height:1.3}.setup-gender-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%}.setup-gender-btn{padding:20px;border-radius:16px;border:2px solid #EDE8E3;background:#fff;font-size:17px;font-weight:600;cursor:pointer;transition:all .2s}.setup-gender-btn:active{transform:scale(.97)}.setup-input-block{width:100%;display:flex;flex-direction:column;align-items:center;gap:16px}.setup-input{width:100%;padding:18px 20px;border-radius:16px;border:2px solid #EDE8E3;background:#fff;font-size:28px;text-align:center;font-weight:700;color:#2d2d2d;outline:none;transition:border-color .2s}.setup-input:focus{border-color:#7db8e8}.setup-btn{width:100%;padding:16px;border-radius:14px;border:none;background:linear-gradient(135deg,#7db8e8,#5bc8c0);color:#fff;font-size:17px;font-weight:700;cursor:pointer;transition:opacity .2s,transform .2s}.setup-btn:active{transform:scale(.98);opacity:.9}.setup-error{color:#e05c6f;font-size:14px;text-align:center}.setup-options{width:100%}.setup-cards{display:flex;flex-direction:column;gap:10px}.setup-card{width:100%;padding:16px 20px;border-radius:14px;border:2px solid #EDE8E3;background:#fff;cursor:pointer;display:flex;flex-direction:column;align-items:flex-start;gap:4px;transition:all .15s;text-align:left}.setup-card:active{transform:scale(.98);border-color:#7db8e8}.setup-card--big{padding:20px}.setup-card__label{font-size:17px;font-weight:700;color:#2d2d2d}.setup-card__desc{font-size:13px;color:#888}.setup-tz-list{display:flex;flex-direction:column;gap:8px}.setup-tz-btn{width:100%;padding:14px 18px;border-radius:12px;border:1px solid #EDE8E3;background:#fff;font-size:15px;text-align:left;cursor:pointer;transition:all .15s}.setup-tz-btn:active{background:#edf7ff;border-color:#7db8e8}.setup-back{margin-top:20px;background:none;border:none;color:#999;font-size:15px;cursor:pointer;padding:8px}.game-page{display:flex;flex-direction:column;background:var(--bg);min-height:100dvh;padding-bottom:0}.game-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;flex-shrink:0}.game-back{background:none;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;padding:6px 0}.game-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0}.game-hud{position:absolute;top:10px;right:12px;display:flex;flex-direction:column;align-items:flex-end;gap:2px;z-index:10;background:#00000061;border-radius:10px;padding:5px 9px}.game-hud__score{font-size:14px;font-weight:700;color:#fff}.game-hud__lives{font-size:14px}.life-empty{filter:grayscale(1) opacity(.4)}.game-canvas-wrap{position:relative;flex:1;display:flex;justify-content:center;align-items:flex-start;overflow:hidden}.game-canvas{display:block;border-radius:16px;cursor:pointer;touch-action:none;box-shadow:0 8px 32px #0003}.game-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:#f4f0ebf0;border-radius:16px;padding:24px;text-align:center}.game-overlay--over{background:#ffe6e6f2}.game-overlay--won{background:#dcffdcf2}.game-overlay__emoji{font-size:52px;margin:0;line-height:1}.game-overlay__title{font-size:24px;font-weight:800;color:var(--text-primary);margin:0}.game-overlay__desc{font-size:14px;color:var(--text-secondary);line-height:1.6;margin:0}.game-overlay__score{font-size:16px;color:var(--text-secondary);margin:0}.game-overlay__xp{font-size:20px;font-weight:700;color:#5ba35a;margin:0}.game-overlay__hint{font-size:12px;color:var(--text-muted);margin:0}.game-overlay__btn{background:linear-gradient(135deg,#7db8e8,#8fd4a3);color:#fff;border:none;border-radius:14px;padding:12px 28px;font-size:15px;font-weight:700;cursor:pointer;width:100%;max-width:220px;transition:opacity .2s}.game-overlay__btn:active{opacity:.8}.game-overlay__btn--ghost{background:none;color:var(--text-secondary);border:1.5px solid var(--border)}.game-controls{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;gap:12px;flex-shrink:0}.game-ctrl-btn{width:72px;height:52px;border-radius:14px;border:none;background:linear-gradient(135deg,#7db8e8,#8fd4a3);color:#fff;font-size:22px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s,opacity .1s;-webkit-user-select:none;user-select:none;flex-shrink:0}.game-ctrl-btn:active{transform:scale(.93);opacity:.85}.game-controls__hint{font-size:11px;color:var(--text-muted);text-align:center;margin:0;flex:1}.game-rules{display:flex;flex-direction:column;gap:8px;padding:12px 16px 20px;flex-shrink:0}.game-rule{display:flex;align-items:center;gap:10px;background:var(--bg-card);border-radius:10px;padding:8px 12px}.game-rule span{font-size:22px;flex-shrink:0}.game-rule p{margin:0;font-size:13px;color:var(--text-secondary)}.chat-page{display:flex;flex-direction:column;height:100dvh;background:var(--bg)}.chat-header{display:flex;align-items:center;gap:12px;padding:14px 16px 12px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.chat-back{background:none;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;padding:6px 0;white-space:nowrap}.chat-header__info{display:flex;align-items:center;gap:10px}.chat-header__orb{position:relative;width:40px;height:40px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.chat-orb-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:linear-gradient(135deg,#7c3aed,#3b82f6,#06b6d4);animation:orb-spin 3s linear infinite;opacity:.85}.chat-orb-ring:after{content:"";position:absolute;top:3px;right:3px;bottom:3px;left:3px;border-radius:50%;background:var(--surface)}@keyframes orb-spin{0%{filter:hue-rotate(0deg) brightness(1.1)}50%{filter:hue-rotate(40deg) brightness(1.3)}to{filter:hue-rotate(0deg) brightness(1.1)}}.chat-orb-video{position:relative;z-index:1;width:34px;height:34px;border-radius:50%;object-fit:cover;pointer-events:none}.chat-header__name{font-size:15px;font-weight:700;color:var(--text-primary);margin:0}.chat-header__sub{font-size:11px;color:var(--text-muted);margin:0}.chat-messages{flex:1;overflow-y:auto;padding:16px 14px;display:flex;flex-direction:column;gap:10px}.chat-bubble{display:flex;align-items:flex-end;gap:8px;max-width:85%;animation:bubble-in .18s ease-out}@keyframes bubble-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.chat-bubble--user{align-self:flex-end;flex-direction:row-reverse}.chat-bubble--assistant{align-self:flex-start}.chat-bubble__avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#7c3aed22,#3b82f622);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;border:1px solid rgba(124,58,237,.15);overflow:hidden}.chat-avatar-video{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block;pointer-events:none}.chat-bubble__text{padding:10px 14px;border-radius:18px;font-size:14px;line-height:1.5;white-space:pre-wrap;word-break:break-word}.chat-bubble--user .chat-bubble__text{background:linear-gradient(135deg,#7c3aed,#3b82f6);color:#fff;border-bottom-right-radius:4px}.chat-bubble--assistant .chat-bubble__text{background:var(--surface);color:var(--text-primary);border-bottom-left-radius:4px}.chat-typing{display:flex;align-items:center;gap:5px;padding:12px 16px!important}.chat-typing span{display:block;width:7px;height:7px;border-radius:50%;background:var(--text-muted);animation:typing-dot 1.2s infinite ease-in-out}.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}@keyframes typing-dot{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-5px);opacity:1}}.chat-input-row{display:flex;align-items:flex-end;gap:10px;padding:10px 14px 16px;background:var(--surface);border-top:1px solid var(--border);flex-shrink:0}.chat-input{flex:1;resize:none;border:1.5px solid var(--border);border-radius:22px;padding:10px 16px;font-size:14px;font-family:inherit;background:#fff;color:var(--text-primary);outline:none;line-height:1.5;max-height:100px;overflow-y:auto;transition:border-color .15s}.chat-input:focus{border-color:#7c3aed}.chat-send-btn{width:40px;height:40px;border-radius:50%;border:none;background:linear-gradient(135deg,#7c3aed,#3b82f6);color:#fff;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:opacity .15s,transform .1s}.chat-send-btn:active{transform:scale(.93)}.chat-send-btn--disabled{opacity:.4;pointer-events:none}.recipes-page{padding-bottom:24px}.recipes-header{display:flex;align-items:center;justify-content:space-between;padding:4px 0 12px}.recipes-back{background:none;border:none;font-size:14px;color:var(--text-muted);cursor:pointer;padding:6px 0;font-weight:600;width:60px}.recipes-cats{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none;margin-bottom:12px}.recipes-cats::-webkit-scrollbar{display:none}.recipes-cat{flex-shrink:0;padding:6px 14px;border-radius:100px;border:1.5px solid var(--border);background:var(--surface);color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.recipes-cat--active{background:linear-gradient(135deg,#7c3aed,#3b82f6);color:#fff;border-color:transparent}.recipes-loading{padding:40px 20px;text-align:center;color:var(--text-muted);font-size:14px}.recipes-empty{padding:60px 20px;text-align:center}.recipes-empty__icon{font-size:52px;margin-bottom:12px}.recipes-empty__title{font-size:17px;font-weight:700;color:var(--text-primary);margin:0 0 6px}.recipes-empty__sub{font-size:13px;color:var(--text-muted);margin:0}.recipes-list{display:flex;flex-direction:column;gap:10px}.recipe-card{cursor:pointer;transition:transform .15s;padding:14px 16px}.recipe-card:active{transform:scale(.98)}.recipe-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:8px}.recipe-card__name{font-size:15px;font-weight:700;color:var(--text-primary);flex:1}.recipe-card__cat{font-size:11px;font-weight:700;color:#7c3aed;background:#7c3aed1a;padding:2px 8px;border-radius:100px;flex-shrink:0}.recipe-card__macros{display:flex;gap:10px;font-size:12px;color:var(--text-muted);flex-wrap:wrap}.recipes-modal{max-height:80vh;overflow-y:auto}.recipes-detail{padding:0 16px 20px}.recipes-detail__macros{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:20px;background:var(--bg);border-radius:var(--radius-md);padding:12px 8px}.recipes-detail__macro{display:flex;flex-direction:column;align-items:center;gap:2px}.recipes-detail__macro-val{font-size:16px;font-weight:800;color:var(--text-primary)}.recipes-detail__macro-label{font-size:11px;color:var(--text-muted)}.recipes-detail__section{font-size:14px;font-weight:700;color:var(--text-primary);margin:0 0 10px}.recipes-detail__ingredients{list-style:none;padding:0;margin:0 0 16px;display:flex;flex-direction:column;gap:6px}.recipes-detail__ingredients li{font-size:13px;color:var(--text-primary);padding:6px 10px;background:var(--bg);border-radius:8px}.recipes-detail__steps{font-size:13px;color:var(--text-primary);line-height:1.7;margin:0;white-space:pre-wrap}.profile-page{padding-bottom:24px}.profile-header{display:flex;align-items:center;justify-content:space-between;padding:4px 0 12px}.profile-back{background:none;border:none;font-size:14px;color:var(--text-muted);cursor:pointer;padding:6px 0;font-weight:600;width:60px}.profile-section-label{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;margin:14px 0 6px;padding:0 2px}.profile-list{display:flex;flex-direction:column}.profile-row{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;cursor:pointer;margin-bottom:4px;transition:opacity .15s}.profile-row:active{opacity:.75}.profile-row--static{cursor:default}.profile-row--static:active{opacity:1}.profile-row__label{font-size:15px;color:var(--text-primary)}.profile-row__value{font-size:14px;color:var(--text-muted);font-weight:600;display:flex;align-items:center;gap:6px}.profile-row__edit{font-size:12px;opacity:.5}.profile-modal{max-height:80vh;overflow-y:auto}.onboarding-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:flex-end;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.onboarding-modal{background:#fff;border-radius:24px 24px 0 0;width:100%;padding:20px 0 32px;display:flex;flex-direction:column;gap:0;animation:slideUp .35s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.onboarding-dots{display:flex;justify-content:center;gap:8px;margin-bottom:20px}.onboarding-dot{width:8px;height:8px;border-radius:50%;background:#e0ddd8;transition:all .3s}.onboarding-dot.active{background:#7db8e8;width:24px;border-radius:4px}.onboarding-dot.done{background:#8fd4a3}.onboarding-body{padding:0 24px;display:flex;flex-direction:column;align-items:center;text-align:center}.onboarding-icon{font-size:52px;margin-bottom:12px;line-height:1}.onboarding-title{font-size:22px;font-weight:700;color:#1a1a1a;margin:0 0 8px}.onboarding-text{font-size:14px;color:#666;margin:0 0 20px;line-height:1.5}.onboarding-items{width:100%;display:flex;flex-direction:column;gap:8px;margin-bottom:4px}.onboarding-item{display:flex;align-items:center;gap:10px;background:#f9f7f4;border-radius:12px;padding:10px 14px}.onboarding-item__icon{font-size:20px;flex-shrink:0}.onboarding-item__label{flex:1;font-size:14px;font-weight:500;color:#333;text-align:left}.onboarding-item__xp{font-size:13px;font-weight:700;color:#7db8e8}.onboarding-footer{display:flex;gap:10px;padding:20px 24px 0;align-items:center}.onboarding-skip{flex:1;background:none;border:1px solid #E0DDD8;border-radius:14px;padding:12px 16px;font-size:15px;color:#999;cursor:pointer}.onboarding-next{flex:2;background:#7db8e8;border:none;border-radius:14px;padding:13px 16px;font-size:16px;font-weight:700;color:#fff;cursor:pointer}.onboarding-start{flex:1;background:linear-gradient(135deg,#7db8e8,#5a9fd4);border:none;border-radius:14px;padding:14px 16px;font-size:17px;font-weight:700;color:#fff;cursor:pointer;width:100%}.sub-expired-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d1;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px}.sub-expired-card{background:linear-gradient(160deg,#1a1a2e,#16213e 60%,#0f3460);border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:32px 24px 28px;width:100%;max-width:360px;text-align:center;box-shadow:0 24px 80px #0009}.sub-expired-icon{font-size:52px;margin-bottom:12px;display:block;filter:drop-shadow(0 4px 16px rgba(255,255,255,.15))}.sub-expired-title{font-size:22px;font-weight:700;color:#fff;margin:0 0 12px;letter-spacing:-.3px}.sub-expired-desc{font-size:14px;color:#ffffffa6;line-height:1.55;margin:0 0 24px}.sub-expired-plans{display:flex;gap:8px;margin-bottom:24px}.sub-expired-plan{flex:1;background:#ffffff12;border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:12px 6px;display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;transition:border-color .2s}.sub-expired-plan--popular{background:#63b3ed1f;border-color:#63b3ed66}.sub-expired-plan__badge{position:absolute;top:-10px;left:50%;transform:translate(-50%);background:linear-gradient(90deg,#667eea,#764ba2);color:#fff;font-size:9px;font-weight:600;padding:2px 8px;border-radius:20px;white-space:nowrap;letter-spacing:.3px}.sub-expired-plan__icon{font-size:20px}.sub-expired-plan__name{font-size:11px;font-weight:600;color:#fffc}.sub-expired-plan__price{font-size:11px;color:#ffffff80;line-height:1.3;text-align:center}.sub-expired-btn{width:100%;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:16px;font-weight:700;border:none;border-radius:16px;cursor:pointer;letter-spacing:.2px;box-shadow:0 8px 24px #667eea66;transition:opacity .15s,transform .1s;margin-bottom:12px}.sub-expired-btn:active{opacity:.88;transform:scale(.98)}.sub-expired-hint{font-size:12px;color:#ffffff59;margin:0}:root{--bg: #F5F0EA;--bg-card: #FFFFFF;--bg-card-soft: #FBF8F5;--color-blue: #7DB8E8;--color-blue-light: #C8E2F5;--color-pink: #F4A8B5;--color-pink-light: #FBD8DF;--color-green: #8FD4A3;--color-green-light: #CBF0D8;--color-teal: #7ECDC8;--color-teal-light: #C4EDEB;--color-yellow: #FFD485;--color-purple: #B8A8E8;--text-primary: #1C1C1E;--text-secondary: #6B6B6B;--text-muted: #A8A8A8;--shadow-sm: 0 2px 8px rgba(0,0,0,.06);--shadow-md: 0 4px 16px rgba(0,0,0,.09);--shadow-lg: 0 8px 32px rgba(0,0,0,.12);--radius-sm: 12px;--radius-md: 16px;--radius-lg: 24px;--radius-xl: 32px;--font: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--nav-height: 72px;--safe-bottom: env(safe-area-inset-bottom, 0px)}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{font-family:var(--font);background:var(--bg);color:var(--text-primary);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.app{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;background:var(--bg)}.page{flex:1;overflow-y:auto;overflow-x:hidden;padding:16px 16px calc(var(--nav-height) + var(--safe-bottom) + 8px);-webkit-overflow-scrolling:touch}.page::-webkit-scrollbar{display:none}button{font-family:var(--font);cursor:pointer;border:none;outline:none;-webkit-appearance:none}a{text-decoration:none;color:inherit}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes slideInRight{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes checkmark{0%{transform:scale(0) rotate(-45deg)}to{transform:scale(1) rotate(0)}}.animate-fadein{animation:fadeInUp .4s ease both}.animate-scalein{animation:scaleIn .3s ease both}.stagger-1{animation-delay:.05s}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.stagger-6{animation-delay:.3s}.stagger-7{animation-delay:.35s}.card{background:var(--bg-card);border-radius:var(--radius-md);padding:16px;box-shadow:var(--shadow-sm)}.card-soft{background:var(--bg-card-soft);border-radius:var(--radius-md);padding:16px}.gradient-blue{background:linear-gradient(135deg,#7db8e8,#9bc8ee)}.gradient-pink{background:linear-gradient(135deg,#f4a8b5,#f9c4cc)}.gradient-green{background:linear-gradient(135deg,#8fd4a3,#a8e0b8)}.gradient-teal{background:linear-gradient(135deg,#7ecdc8,#9ad9d5)}.gradient-main{background:linear-gradient(135deg,#7db8e8,#8fd4a3,#f4a8b5)}.section-title{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:12px}.btn-primary{width:100%;padding:16px;border-radius:var(--radius-md);font-size:16px;font-weight:600;color:#fff;background:linear-gradient(135deg,#7db8e8,#8fd4a3);box-shadow:0 4px 16px #7db8e866;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.btn-primary:active{transform:scale(.97);box-shadow:0 2px 8px #7db8e84d}.btn-secondary{width:100%;padding:14px;border-radius:var(--radius-md);font-size:15px;font-weight:600;color:var(--text-primary);background:var(--bg-card);box-shadow:var(--shadow-sm);transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.btn-secondary:active{transform:scale(.97)}.plan-generating{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;gap:12px}.plan-generating__hamster{font-size:56px;animation:hamsterBounce 1.4s ease-in-out infinite;line-height:1}.plan-generating__title{font-size:17px;font-weight:600;color:var(--text-primary);line-height:1.5;margin:0}.plan-generating__sub{font-size:14px;color:var(--text-muted);margin:0}.plan-generating__dots{display:flex;gap:6px;margin-top:4px}.plan-generating__dots span{width:7px;height:7px;border-radius:50%;background:var(--color-blue);animation:dotPulse 1.2s ease-in-out infinite}.plan-generating__dots span:nth-child(2){animation-delay:.2s}.plan-generating__dots span:nth-child(3){animation-delay:.4s}@keyframes hamsterBounce{0%,to{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-8px) rotate(3deg)}}@keyframes dotPulse{0%,80%,to{transform:scale(.7);opacity:.4}40%{transform:scale(1);opacity:1}}.app{position:relative;overflow:hidden}.app--loaded .page-wrapper{animation:fadeInUp .35s ease both}.bg-blob{position:fixed;border-radius:50%;filter:blur(60px);z-index:0;pointer-events:none}.bg-blob--1{width:300px;height:300px;background:radial-gradient(circle,rgba(125,184,232,.15),transparent 70%);top:-100px;right:-80px}.bg-blob--2{width:250px;height:250px;background:radial-gradient(circle,rgba(143,212,163,.12),transparent 70%);bottom:100px;left:-80px}.page-wrapper{position:relative;z-index:1;flex:1;display:flex;flex-direction:column}.splash{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);z-index:999;display:flex;align-items:center;justify-content:center}.splash__logo{display:flex;flex-direction:column;align-items:center;gap:16px;animation:scaleIn .4s ease}.splash__ring{width:72px;height:72px;border-radius:50%;border:4px solid transparent;border-top-color:#7db8e8;border-right-color:#f4a8b5;border-bottom-color:#8fd4a3;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.splash__name{font-size:28px;font-weight:800;letter-spacing:3px;background:linear-gradient(135deg,#7db8e8,#8fd4a3,#f4a8b5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
