@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-base: #090B0E;--bg-surface: #13161C;--bg-card: #1A1E28;--bg-lift: #222736;--bg-input: #1E2230;--brand: #10B981;--brand-dim: rgba(16,185,129,.15);--brand-glow: rgba(16,185,129,.35);--danger: #EF4444;--warn: #F59E0B;--info: #3B82F6;--success: #10B981;--text-1: #F1F3F7;--text-2: #9CA3AF;--text-3: #6B7280;--border: rgba(255,255,255,.07);--border-md:rgba(255,255,255,.12);--r-sm: 10px;--r-md: 16px;--r-lg: 22px;--r-xl: 30px;--nav-bottom: 72px;--nav-top: 60px;--safe-b: env(safe-area-inset-bottom, 0px);--safe-t: env(safe-area-inset-top, 0px);--tap-min: 48px;--ease: cubic-bezier(.4,0,.2,1);--ease-spring: cubic-bezier(.34,1.56,.64,1);--t-fast: .12s;--t-base: .22s;--t-slow: .38s;--font: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "SF Mono", "Fira Code", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;height:100%}body{font-family:var(--font);background:var(--bg-base);color:var(--text-1);min-height:100dvh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior-y:none}#root{display:flex;flex-direction:column;min-height:100dvh;width:100%;overflow-x:hidden}h1{font-size:1.75rem;font-weight:700;letter-spacing:-.02em;line-height:1.2}h2{font-size:1.375rem;font-weight:600;letter-spacing:-.01em;line-height:1.3}h3{font-size:1.125rem;font-weight:600;line-height:1.4}h4{font-size:1rem;font-weight:500}p{line-height:1.6}.app-shell{display:flex;flex-direction:column;min-height:100dvh;max-width:480px;margin:0 auto;position:relative}.app-content{flex:1;overflow-y:auto;overflow-x:hidden;padding-bottom:calc(var(--nav-bottom) + var(--safe-b) + 16px);padding-top:calc(var(--safe-t) + 16px);-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;touch-action:pan-y;will-change:scroll-position}@media (min-width: 768px){.app-shell{max-width:100%;flex-direction:row}.app-content{margin-left:240px;padding-bottom:24px;padding-top:calc(var(--nav-top) + 24px);max-width:800px;padding-left:24px;padding-right:24px}}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-bottom) + var(--safe-b));padding-bottom:var(--safe-b);background:#0d0f14eb;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--border);display:flex;align-items:flex-start;padding-top:8px;z-index:1000}.bottom-nav__item{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;min-height:var(--tap-min);padding:4px 0;background:none;border:none;cursor:pointer;color:var(--text-3);font-size:.65rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;transition:color var(--t-fast) var(--ease);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;position:relative}.bottom-nav__item:active{transform:scale(.92)}.bottom-nav__item.active{color:var(--brand)}.bottom-nav__icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:10px;transition:background var(--t-fast) var(--ease)}.bottom-nav__item.active .bottom-nav__icon{background:var(--brand-dim)}.bottom-nav__dot{position:absolute;top:2px;right:calc(50% - 16px);width:6px;height:6px;border-radius:50%;background:var(--brand)}@media (min-width: 768px){.bottom-nav{display:none}}.side-nav{display:none}@media (min-width: 768px){.side-nav{display:flex;flex-direction:column;position:fixed;top:0;left:0;width:240px;height:100dvh;background:var(--bg-surface);border-right:1px solid var(--border);padding:24px 16px;z-index:100;gap:4px;overflow-y:auto}.side-nav__logo{display:flex;align-items:center;gap:10px;padding:8px 12px 20px;border-bottom:1px solid var(--border);margin-bottom:8px;color:var(--text-1);font-weight:700;font-size:1.1rem}.side-nav__item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--r-md);background:none;border:none;color:var(--text-2);font-size:.9rem;font-weight:500;cursor:pointer;transition:all var(--t-fast) var(--ease);width:100%;text-align:left;-webkit-tap-highlight-color:transparent;position:relative}.side-nav__item:hover{background:var(--bg-card);color:var(--text-1)}.side-nav__item.active{background:var(--brand-dim);color:var(--brand)}.side-nav__badge{margin-left:auto;font-size:.7rem;font-weight:600;background:var(--brand);color:#000;padding:2px 7px;border-radius:99px}}.top-bar{position:sticky;top:0;left:0;right:0;height:var(--nav-top);background:#090b0ee0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 16px;z-index:500}@media (min-width: 768px){.top-bar{left:240px;padding:0 24px;height:var(--nav-top)}}.timer-strip{position:sticky;top:var(--nav-top);z-index:400;background:#090b0eeb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);overflow:hidden}.timer-strip__item{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border)}.timer-strip__item:last-child{border-bottom:none}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:border-color var(--t-fast) var(--ease)}.card-press{cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.card-press:active{transform:scale(.985)}@media (hover: hover){.card-press:hover{border-color:var(--border-md)}}.card-glass{background:#1a1e28bf;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--r-lg)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:var(--tap-min);padding:0 20px;border-radius:var(--r-md);font-family:var(--font);font-size:.95rem;font-weight:600;cursor:pointer;border:none;transition:all var(--t-fast) var(--ease);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;white-space:nowrap}.btn:active{transform:scale(.96)}.btn-primary{background:var(--brand);color:#000;box-shadow:0 0 24px var(--brand-glow)}.btn-primary:active{box-shadow:none}@media (hover: hover){.btn-primary:hover{filter:brightness(1.08)}}.btn-ghost{background:var(--bg-lift);color:var(--text-1);border:1px solid var(--border-md)}@media (hover: hover){.btn-ghost:hover{background:var(--bg-card);border-color:var(--border-md)}}.btn-danger{background:#ef444426;color:var(--danger);border:1px solid rgba(239,68,68,.25)}@media (hover: hover){.btn-danger:hover{background:#ef444440}}.btn-icon{width:var(--tap-min);height:var(--tap-min);padding:0;border-radius:var(--r-sm);background:var(--bg-lift);color:var(--text-2);border:1px solid var(--border)}@media (hover: hover){.btn-icon:hover{color:var(--text-1);border-color:var(--border-md)}}.fab{position:fixed;bottom:calc(var(--nav-bottom) + var(--safe-b) + 16px);right:20px;width:56px;height:56px;border-radius:50%;background:var(--brand);color:#000;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 24px var(--brand-glow);z-index:200;transition:all var(--t-base) var(--ease-spring);-webkit-tap-highlight-color:transparent}.fab:active{transform:scale(.9)}@media (hover: hover){.fab:hover{transform:scale(1.06)}}@media (min-width: 768px){.fab{bottom:24px}}.input,.select,textarea{width:100%;min-height:var(--tap-min);padding:0 14px;background:var(--bg-input);border:1px solid var(--border-md);border-radius:var(--r-md);color:var(--text-1);font-family:var(--font);font-size:1rem;transition:border-color var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease);outline:none;-webkit-appearance:none}textarea{padding:12px 14px;min-height:96px;resize:vertical;line-height:1.5}.input:focus,.select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim)}.input::placeholder,textarea::placeholder{color:var(--text-3)}.select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B7280' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}.label{display:block;font-size:.8rem;font-weight:500;color:var(--text-2);margin-bottom:6px;letter-spacing:.03em}.field{display:flex;flex-direction:column;gap:6px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:99px;font-size:.72rem;font-weight:600;letter-spacing:.04em}.badge-green{background:#10b98126;color:#34d399}.badge-amber{background:#f59e0b2e;color:#92400e}.badge-red{background:#ef444426;color:#fca5a5}.badge-blue{background:#3b82f626;color:#93c5fd}.badge-purple{background:#8b5cf626;color:#c4b5fd}.badge-gray{background:#6b728026;color:#9ca3af}.list-item{display:flex;align-items:center;gap:12px;min-height:56px;padding:10px 16px;border-bottom:1px solid var(--border);background:transparent;transition:background var(--t-fast) var(--ease);cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.list-item:last-child{border-bottom:none}.list-item:active{background:#ffffff08}@media (hover: hover){.list-item:hover{background:#ffffff08}}.list-item__swipe{position:relative;overflow:hidden}.section-header{font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);padding:20px 16px 8px}.divider{height:1px;background:var(--border);margin:0 16px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:800;display:flex;align-items:flex-end;justify-content:center;animation:fade-in var(--t-fast) var(--ease)}@media (min-width: 480px){.overlay{align-items:center}}.sheet{width:100%;max-width:480px;max-height:92dvh;background:var(--bg-surface);border-top-left-radius:var(--r-xl);border-top-right-radius:var(--r-xl);overflow:hidden;animation:slide-up var(--t-base) var(--ease-spring);display:flex;flex-direction:column}@media (min-width: 480px){.sheet{border-radius:var(--r-xl);animation:pop-in var(--t-base) var(--ease-spring)}}.sheet__handle{width:36px;height:4px;border-radius:99px;background:var(--border-md);margin:12px auto 4px;flex-shrink:0}.sheet__header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.sheet__body{overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1;padding:16px 20px}.confirm-sheet{padding:24px 20px calc(24px + var(--safe-b));text-align:center;display:flex;flex-direction:column;gap:12px}.confirm-sheet h3{font-size:1.1rem}.confirm-sheet p{color:var(--text-2);font-size:.9rem}.toast-container{position:fixed;top:calc(var(--safe-t) + var(--nav-top) + 12px);left:50%;transform:translate(-50%);z-index:900;display:flex;flex-direction:column;gap:8px;pointer-events:none;width:min(calc(100vw - 32px),400px)}@media (min-width: 768px){.toast-container{left:calc(120px + 50%)}}.toast{background:var(--bg-lift);border:1px solid var(--border-md);border-radius:var(--r-md);padding:12px 16px;font-size:.875rem;font-weight:500;color:var(--text-1);display:flex;align-items:center;gap:10px;animation:slide-down var(--t-base) var(--ease-spring);pointer-events:all}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 24px;text-align:center;color:var(--text-2)}.empty-state__icon{font-size:3rem;opacity:.5}.empty-state h3{color:var(--text-1);font-size:1.1rem}.empty-state p{font-size:.875rem;max-width:260px}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,var(--bg-card) 25%,var(--bg-lift) 50%,var(--bg-card) 75%);background-size:800px 100%;animation:shimmer 1.4s infinite;border-radius:var(--r-sm)}.progress-bar{height:4px;background:var(--border);border-radius:99px;overflow:hidden}.progress-bar__fill{height:100%;background:var(--brand);border-radius:99px;transition:width var(--t-slow) var(--ease)}.thumb-zone{padding:0 20px 24px}.check-wrap{display:flex;align-items:center;min-height:var(--tap-min);gap:12px;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.check-box{width:24px;height:24px;border-radius:7px;border:2px solid var(--border-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--t-fast) var(--ease-spring)}.check-box.checked{background:var(--brand);border-color:var(--brand)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slide-down{0%{transform:translateY(-12px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pop-in{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.anim-fade-up{animation:slide-up var(--t-base) var(--ease) both}.anim-pop{animation:pop-in var(--t-base) var(--ease-spring) both}.anim-stagger>*{animation:slide-up var(--t-base) var(--ease) both}.anim-stagger>*:nth-child(1){animation-delay:0ms}.anim-stagger>*:nth-child(2){animation-delay:60ms}.anim-stagger>*:nth-child(3){animation-delay:.12s}.anim-stagger>*:nth-child(4){animation-delay:.18s}.anim-stagger>*:nth-child(5){animation-delay:.24s}.spin{animation:spin 1s linear infinite}.scroll-row{display:flex;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:4px 16px 12px;margin:0 -16px}.scroll-row::-webkit-scrollbar{display:none}.scroll-row>*{scroll-snap-align:start;flex-shrink:0}button{font-family:var(--font);cursor:pointer}a{color:var(--brand);text-decoration:none}img{display:block;max-width:100%}.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}.health-a{color:#34d399}.health-b{color:#fcd34d}.health-c{color:#fca5a5}.coin-badge{display:inline-flex;align-items:center;gap:4px;background:#facc151f;color:#fcd34d;padding:4px 10px;border-radius:99px;font-size:.8rem;font-weight:700}.recipe-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:transparent}.recipe-card:active{transform:scale(.985)}@media (hover: hover){.recipe-card:hover{border-color:var(--border-md)}}.recipe-card__img{width:100%;aspect-ratio:16/9;object-fit:cover}.recipe-card__body{padding:14px 16px}.macro-row{display:flex;gap:8px;flex-wrap:wrap}.macro-pill{font-size:.72rem;font-weight:600;padding:3px 9px;border-radius:99px;background:var(--bg-lift);color:var(--text-2)}.macro-pill.kcal{color:#fcd34d;background:#facc151a}.macro-pill.prot{color:#6ee7b7;background:#10b9811a}.macro-pill.carbs{color:#93c5fd;background:#3b82f61a}.macro-pill.fat{color:#fca5a5;background:#ef44441a}.diff-easy{color:#34d399}.diff-medium{color:#fcd34d}.diff-hard{color:#fca5a5}@media (prefers-color-scheme: light){:root{--bg-base: #F0F4F8;--bg-surface: #FFFFFF;--bg-card: #F8FAFC;--bg-lift: #EDF2F7;--bg-input: #FFFFFF;--text-1: #0F172A;--text-2: #475569;--text-3: #94A3B8;--border: rgba(0,0,0,.08);--border-md: rgba(0,0,0,.14);--brand: #059669;--brand-dim: rgba(5,150,105,.12);--brand-glow: rgba(5,150,105,.25);--danger: #DC2626;--warn: #D97706;--info: #2563EB;--success: #059669}body{-webkit-font-smoothing:subpixel-antialiased}.card{box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;border-color:#0000000f}.btn-primary{box-shadow:0 1px 4px #0596694d}.input{border-color:#0000001f}.input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim)}.overlay{background:#0006}.recharts-tooltip-wrapper .recharts-default-tooltip{background:#fff!important;border:1px solid rgba(0,0,0,.1)!important;color:#0f172a!important}}body{transition:background-color .2s var(--ease),color .2s var(--ease)}.recharts-text{font-family:var(--font)!important}.recharts-cartesian-axis-tick-value{fill:var(--text-3)!important;font-size:11px}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:var(--border)!important}.recharts-legend-item-text{color:var(--text-2)!important;font-size:.8rem}.virtual-list-outer{outline:none}@keyframes ach-enter{0%{opacity:0;transform:translate(-50%) translateY(-20px) scale(.9)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.premium-ribbon{position:absolute;top:0;left:0;background:linear-gradient(135deg,#d97706,#f59e0b);padding:3px 10px 3px 8px;border-radius:0 0 10px;font-size:.55rem;font-weight:800;color:#000;text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:3px}.level-max{box-shadow:0 0 12px #f59e0b66}::view-transition-old(root){animation:.12s ease-out both vt-fade-out}::view-transition-new(root){animation:.12s ease-in both vt-fade-in}@keyframes vt-fade-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-6px)}}@keyframes vt-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes step-slide-in{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.step-card-active{animation:step-slide-in .2s var(--ease) both}@keyframes step-complete{0%{transform:scale(1)}40%{transform:scale(1.04)}to{transform:scale(1)}}.step-card-done{animation:step-complete .28s var(--ease) both}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--bg-lift) 25%,var(--border) 50%,var(--bg-lift) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:8px}.btn-primary:active{transform:scale(.96)}@keyframes coin-pop{0%{transform:scale(1)}50%{transform:scale(1.25)}to{transform:scale(1)}}.coin-badge--earned{animation:coin-pop .35s var(--ease)}@keyframes card-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.card-in{animation:card-in .18s var(--ease) both}
