:root{--bg-primary:var(--tg-theme-bg-color,#0d0d0f);--bg-secondary:var(--tg-theme-secondary-bg-color,#1a1a2e);--bg-card:#16213e;--accent:var(--tg-theme-button-color,#ff6b35);--accent-hover:#ff8255;--accent-glow:#ff6b354d;--text-primary:var(--tg-theme-text-color,#fff);--text-secondary:var(--tg-theme-hint-color,#fff9);--text-muted:#ffffff59;--link-color:var(--tg-theme-link-color,#60a5fa);--button-text:var(--tg-theme-button-text-color,#fff);--score-bad:#ff3b30;--score-mid:#ffd60a;--score-good:#30d158;--surface-glass:#ffffff0f;--border-glass:#ffffff1a}*,:before,:after{box-sizing:border-box}html,body,#root{color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;max-width:100vw;min-height:100vh;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif;overflow-x:hidden;background:var(--bg-primary)!important}.text-display{color:var(--text-primary);font-size:32px;font-weight:700;line-height:1.2}.text-h1{color:var(--text-primary);font-size:28px;font-weight:700;line-height:1.3}.text-h2{color:var(--text-primary);font-size:22px;font-weight:600;line-height:1.3}.text-body{color:var(--text-primary);font-size:16px;font-weight:400;line-height:1.5}.text-caption{color:var(--text-secondary);font-size:13px;font-weight:400;line-height:1.4}.text-score{color:var(--text-primary);font-size:48px;font-weight:800;line-height:1}.glass-card{background:var(--surface-glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-glass);border-radius:16px;padding:16px}.glass-card-sm{background:var(--surface-glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-glass);border-radius:12px;padding:12px 16px}.btn-accent{background:var(--accent);width:100%;color:var(--button-text);cursor:pointer;box-shadow:0 0 30px var(--accent-glow);-webkit-tap-highlight-color:transparent;border:none;border-radius:16px;justify-content:center;align-items:center;gap:8px;padding:16px 24px;font-size:16px;font-weight:600;transition:all .2s;display:flex}.btn-accent:active{background:var(--accent-hover);transform:scale(.97)}.btn-icon-glass{background:var(--surface-glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-glass);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;transition:all .2s;display:flex}.btn-icon-glass:active{background:#ffffff1a;transform:scale(.92)}.btn-glass{background:var(--surface-glass);-webkit-backdrop-filter:blur(20px);width:100%;color:var(--text-primary);border:1px solid var(--border-glass);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:16px;justify-content:center;align-items:center;gap:8px;padding:16px 24px;font-size:16px;font-weight:600;transition:all .2s;display:flex}.btn-glass:active{background:#ffffff1a;transform:scale(.97)}.btn-glass-secondary{width:100%;color:var(--text-secondary);border:1px solid var(--border-glass);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border-radius:16px;justify-content:center;align-items:center;gap:8px;padding:16px 24px;font-size:16px;font-weight:500;transition:all .2s;display:flex}.btn-glass-secondary:active{background:var(--surface-glass);transform:scale(.97)}.camera-btn{background:var(--accent);cursor:pointer;width:100px;height:100px;box-shadow:0 0 40px var(--accent-glow), 0 0 80px #ff6b3526;-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;justify-content:center;align-items:center;transition:transform .2s;animation:2s ease-in-out infinite cameraPulse;display:flex}.camera-btn:active{animation:none;transform:scale(.92)}.camera-btn svg{color:#fff;width:40px;height:40px}.score-circle{z-index:10;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:100px;height:100px;display:flex;position:relative}.score-circle:before{content:"";background:var(--score-gradient);-webkit-mask-composite:xor;border-radius:50%;padding:3px;position:absolute;inset:-3px;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;-webkit-mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.score-circle.score-bad{--score-gradient:linear-gradient(135deg, #ff3b30, #ff6b6b);background:#ff3b3026;box-shadow:0 0 30px #ff3b304d}.score-circle.score-mid{--score-gradient:linear-gradient(135deg, #ffd60a, #fa0);background:#ffd60a1f;box-shadow:0 0 30px #ffd60a40}.score-circle.score-good{--score-gradient:linear-gradient(135deg, #30d158, #00e676);background:#30d1581f;box-shadow:0 0 30px #30d15840}.score-number{color:var(--text-primary);font-size:36px;font-weight:800;line-height:1}.score-of-ten{color:var(--text-secondary);margin-top:2px;font-size:14px;font-weight:500}.score-badge{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.score-badge.score-bad{color:var(--score-bad);background:#ff3b3033}.score-badge.score-mid{color:var(--score-mid);background:#ffd60a33}.score-badge.score-good{color:var(--score-good);background:#30d15833}.back-btn{top:calc(12px + env(safe-area-inset-top));left:calc(12px + env(safe-area-inset-left));background:var(--surface-glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-glass);cursor:pointer;z-index:20;width:40px;height:40px;color:var(--text-primary);-webkit-tap-highlight-color:transparent;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute}.back-btn:active{background:#ffffff1f}.back-btn svg{width:24px;height:24px}.nutrition-row{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:8px;padding:0 20px 8px;display:flex;overflow-x:auto}.nutrition-row::-webkit-scrollbar{display:none}.nutrition-card{background:var(--surface-glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-glass);text-align:center;border-radius:12px;flex:none;min-width:80px;padding:12px}.nutrition-card .label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:11px;font-weight:500}.nutrition-card .value{color:var(--text-primary);font-size:18px;font-weight:700}.nutrition-card .unit{color:var(--text-secondary);font-size:12px}.hearts-row{justify-content:center;align-items:center;gap:6px;margin-top:8px;font-size:22px;display:flex}.loading-overlay{-webkit-backdrop-filter:blur(10px);z-index:9999;background:#0d0d0fd9;flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.loading-spinner{border:3px solid var(--border-glass);border-top-color:var(--accent);border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}.loading-text{color:var(--text-primary);margin-top:16px;font-size:18px;font-weight:600;animation:1.5s ease-in-out infinite loadingPulse}.error-toast{bottom:calc(40px + env(safe-area-inset-bottom));left:calc(16px + env(safe-area-inset-left));right:calc(16px + env(safe-area-inset-right));-webkit-backdrop-filter:blur(20px);z-index:10000;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#ff3b3026;border:1px solid #ff3b304d;border-radius:16px;align-items:center;gap:12px;padding:16px 20px;animation:.3s ease-out slideUp;display:flex;position:fixed}.error-toast .error-icon{flex-shrink:0;font-size:24px}.error-toast .error-message{color:var(--text-primary);font-size:15px;font-weight:500;line-height:1.4}.screen{background:linear-gradient(180deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);min-height:100vh;padding-top:env(safe-area-inset-top);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);padding-bottom:env(safe-area-inset-bottom);box-sizing:border-box;position:relative}.screen-content{padding:0 20px 40px}.screen-center{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:0 20px;display:flex}@keyframes cameraPulse{0%,to{box-shadow:0 0 40px var(--accent-glow), 0 0 80px #ff6b3526}50%{box-shadow:0 0 60px var(--accent-glow), 0 0 120px #ff6b3540}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scoreReveal{0%{opacity:0;transform:scale(.5)}60%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}@keyframes loadingPulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes floatEmoji{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.animate-fade-in{animation:.4s ease-out fadeIn}.animate-slide-up{animation:.4s ease-out slideUp}.animate-score-reveal{animation:.6s cubic-bezier(.34,1.56,.64,1) scoreReveal}.animate-float{animation:3s ease-in-out infinite floatEmoji}.stats-scroll{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:8px;padding:8px 20px 4px;display:flex;overflow-x:auto}.stats-scroll::-webkit-scrollbar{display:none}.stat-pill{background:var(--surface-glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-glass);white-space:nowrap;border-radius:100px;flex-shrink:0;align-items:center;gap:6px;padding:6px 14px;display:flex}.stat-pill-label{color:var(--text-muted);font-size:12px}.stat-pill-value{color:var(--text-primary);font-size:13px;font-weight:700}.history-card-v2{background:var(--surface-glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-glass);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:16px;align-items:center;gap:14px;padding:14px 16px;transition:all .2s;display:flex}.history-card-v2:active{background:#ffffff14;transform:scale(.98)}.history-score-block{flex-direction:column;flex-shrink:0;align-items:center;gap:2px;display:flex}.history-score-circle{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:18px;font-weight:800;display:flex;box-shadow:0 0 12px #0000004d}.history-score-label{color:var(--text-muted);font-size:11px;font-weight:600}.history-photo-wrap{border-radius:12px;flex-shrink:0;width:56px;height:56px;position:relative;overflow:hidden}.history-photo{object-fit:cover;width:100%;height:100%}.history-photo-score{color:#fff;border:2px solid var(--bg-primary);border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;font-weight:800;display:flex;position:absolute;bottom:-4px;right:-4px}.history-card-info{flex:1;min-width:0}.history-card-dish{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:600;overflow:hidden}.history-card-verdict{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;margin-top:3px;font-size:13px;font-style:italic;overflow:hidden}.history-card-meta{color:var(--text-muted);gap:10px;margin-top:4px;font-size:12px;display:flex}.roast-line{background:var(--surface-glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-glass);color:var(--text-primary);border-radius:12px;padding:14px 16px;font-size:15px;line-height:1.5}.promo-banner{text-align:center;background:linear-gradient(135deg,#ff6b351a,#ff6b3508);border:1px solid #ff6b3526;border-radius:16px;padding:20px}.promo-banner .promo-title{color:var(--text-primary);margin-bottom:4px;font-size:15px;font-weight:600}.promo-banner .promo-subtitle{color:var(--text-secondary);margin-bottom:16px;font-size:13px;line-height:1.4}.result-photo-wrap{background:var(--bg-secondary);width:100%;height:280px;position:relative;overflow:hidden}.result-photo{object-fit:cover;width:100%;height:100%;display:block}.result-photo-gradient{background:linear-gradient(transparent, var(--bg-primary));pointer-events:none;height:120px;position:absolute;bottom:0;left:0;right:0}.nav-link{color:var(--link-color);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;padding:8px;font-size:15px;font-weight:600}.nav-link:active{opacity:.7}.bg-blobs{z-index:0;pointer-events:none;position:fixed;inset:0;overflow:hidden}.bg-blobs:before,.bg-blobs:after{content:"";filter:blur(100px);opacity:.07;border-radius:50%;animation:20s ease-in-out infinite alternate blob-drift;position:absolute}.bg-blobs:before{background:#a855f7;width:400px;height:400px;top:-10%;left:-10%}.bg-blobs:after{background:#ff6b35;width:350px;height:350px;animation-delay:-10s;bottom:-10%;right:-10%}@keyframes blob-drift{0%{transform:translate(0)scale(1)}33%{transform:translate(30px,-20px)scale(1.1)}66%{transform:translate(-20px,30px)scale(.95)}to{transform:translate(10px,10px)scale(1.05)}}.powerup-card{background:var(--surface-glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-glass);cursor:pointer;-webkit-tap-highlight-color:transparent;text-align:left;border-radius:20px;align-items:center;gap:16px;width:100%;padding:20px;transition:all .2s;display:flex}.powerup-card:active{background:#ffffff14;transform:scale(.97)}.powerup-card--accent{border-color:var(--accent);box-shadow:0 0 20px var(--accent-glow)}.powerup-icon{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex}.powerup-text{flex:1;min-width:0}.powerup-title{color:var(--text-primary);font-size:16px;font-weight:600;line-height:1.3}.powerup-subtitle{color:var(--text-secondary);margin-top:2px;font-size:13px;line-height:1.4}.powerup-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:6px;flex-shrink:0;padding:3px 8px;font-size:11px;font-weight:700}.powerup-badge--free{color:var(--score-good);background:#30d15826}.powerup-badge--price{color:var(--accent);background:#ff6b3526}.powerup-arrow{color:var(--text-muted);flex-shrink:0;font-size:18px}.result-photo-enter{opacity:0;animation:.5s ease-out forwards resultPhotoIn}@keyframes resultPhotoIn{0%{opacity:0;transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.result-score-enter{opacity:0;animation:.5s cubic-bezier(.34,1.56,.64,1) .3s forwards resultScoreBounce}@keyframes resultScoreBounce{0%{opacity:0;transform:scale(0)}70%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.result-verdict-enter{opacity:0;animation:.4s ease-out .6s forwards resultSlideUp}@keyframes resultSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.result-roast-enter{opacity:0;animation:.4s ease-out forwards resultRoastSlideIn}@keyframes resultRoastSlideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.result-buttons-enter{opacity:0;animation:.4s ease-out 1.2s forwards resultSlideUp}.streak-badge{background:var(--surface-glass);border:1px solid var(--border-glass);color:var(--text-secondary);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:20px;align-items:center;gap:4px;padding:6px 14px;font-size:13px;font-weight:600;display:inline-flex}.pc-wrap{width:100%;overflow:hidden}.pc-scroll{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:16px;padding:8px calc(50vw - 40px);display:flex;overflow-x:auto}.pc-scroll::-webkit-scrollbar{display:none}.pc-item{scroll-snap-align:center;cursor:pointer;flex-direction:column;flex-shrink:0;align-items:center;gap:6px;transition:transform .2s;display:flex}.pc-item:active{transform:scale(.93)}.pc-avatar{border:2px solid #0000;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;transition:all .25s;display:flex;position:relative}.pc-avatar--active{border-color:var(--accent);width:76px;height:76px;box-shadow:0 0 20px var(--accent-glow), 0 0 40px var(--accent-glow)}.pc-emoji{font-size:28px;line-height:1}.pc-avatar--active .pc-emoji{font-size:34px}.pc-item--locked .pc-avatar{filter:grayscale(.6)brightness(.7)}.pc-lock{background:var(--surface-glass);border:1px solid var(--border-glass);border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:14px;display:flex;position:absolute;bottom:-2px;right:-2px}.pc-label{color:var(--text-secondary);white-space:nowrap;font-size:11px;font-weight:500;transition:color .2s}.pc-label--active{color:var(--text-primary);font-weight:600}.leaderboard-card{background:var(--surface-glass);border:1px solid var(--border-glass);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:16px;align-items:center;gap:12px;padding:12px 14px;display:flex}.lb-position{text-align:center;flex-shrink:0;width:32px}.lb-position-num{color:var(--text-muted);font-size:16px;font-weight:700}.lb-photo-wrap{border-radius:12px;flex-shrink:0;width:48px;height:48px;overflow:hidden}.lb-photo{object-fit:cover;width:100%;height:100%}.lb-score-circle{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:18px;font-weight:700;display:flex}.lb-info{flex:1;min-width:0}.lb-dish{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.lb-verdict{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:12px;overflow:hidden}.lb-score-badge{flex-shrink:0;font-size:15px;font-weight:700}.ach-progress-wrap{align-items:center;gap:12px;margin:16px 0 24px;padding:0 4px;display:flex}.ach-progress-bar{background:var(--surface-glass);border:1px solid var(--border-glass);border-radius:4px;flex:1;height:8px;overflow:hidden}.ach-progress-fill{background:linear-gradient(90deg, var(--accent), #ffd60a);border-radius:4px;height:100%;transition:width .4s}.ach-progress-text{color:var(--text-secondary);white-space:nowrap;font-size:14px;font-weight:700}.ach-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.ach-card{background:var(--surface-glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-glass);text-align:center;border-radius:16px;padding:16px 12px;transition:all .3s}.ach-card--unlocked{border-color:#ffd60a4d;box-shadow:0 0 20px #ffd60a1a}.ach-card--locked{opacity:.5}.ach-icon{background:var(--surface-glass);border:2px solid var(--border-glass);border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 10px;display:flex}.ach-icon--unlocked{background:linear-gradient(135deg,#ffd60a26,#ff6b351a);border-color:#ffd60a66;box-shadow:0 0 16px #ffd60a33}.ach-emoji{font-size:28px}.ach-lock{filter:grayscale();font-size:22px}.ach-name{color:var(--text-primary);margin-bottom:2px;font-size:14px;font-weight:600}.ach-desc{color:var(--text-muted);font-size:12px;line-height:1.3}.ach-date{color:var(--text-muted);margin-top:6px;font-size:11px}.ach-toast{top:calc(20px + env(safe-area-inset-top));left:calc(16px + env(safe-area-inset-left));right:calc(16px + env(safe-area-inset-right));-webkit-backdrop-filter:blur(20px);z-index:10001;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#ffd60a1a;border:1px solid #ffd60a4d;border-radius:16px;align-items:center;gap:12px;padding:14px 18px;animation:.4s ease-out achToastIn;display:flex;position:fixed}.ach-toast-icon{flex-shrink:0;font-size:32px}.ach-toast-text{flex:1}.ach-toast-title{color:#ffd60a;font-size:14px;font-weight:700}.ach-toast-name{color:var(--text-primary);margin-top:2px;font-size:13px}@keyframes achToastIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}[data-theme=light]{--bg-primary:var(--tg-theme-bg-color,#fff);--bg-secondary:var(--tg-theme-secondary-bg-color,#f0f0f0);--bg-card:var(--tg-theme-secondary-bg-color,#f0f0f0);--text-primary:var(--tg-theme-text-color,#000);--text-secondary:var(--tg-theme-hint-color,#999);--text-muted:#00000059;--surface-glass:#0000000a;--border-glass:#00000014}[data-theme=light] .camera-btn svg{color:#fff}[data-theme=light] .btn-icon-glass:active{background:#00000014}[data-theme=light] .btn-glass:active{background:#0000000f}[data-theme=light] .btn-glass-secondary:active{background:#0000000a}[data-theme=light] .back-btn:active{background:#00000014}[data-theme=light] .powerup-card:active,[data-theme=light] .history-card-v2:active{background:#0000000f}[data-theme=light] .history-score-circle{color:#fff}[data-theme=light] .history-photo-score{color:#fff;border-color:var(--bg-primary)}[data-theme=light] .score-badge{color:#fff}[data-theme=light] .loading-overlay{background:#ffffffd9}[data-theme=light] .ach-toast-title{color:#b8960a}[data-theme=light] .bg-blobs:before{opacity:.03;background:#6200ea}[data-theme=light] .bg-blobs:after{opacity:.03;background:#ff6b35}[data-theme=light] .loading-spinner{border-color:#00000026;border-top-color:var(--accent)}[data-theme=light] .error-toast{background:#ff3b3014;border-color:#ff3b304d}[data-theme=light] .result-photo-gradient{background:linear-gradient(#0000,#ffffffd9)}[data-theme=light] .score-circle{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0000000f}[data-theme=light] .score-circle.score-good{background:#30d15826}[data-theme=light] .score-circle.score-mid{background:#ffd60a26}[data-theme=light] .score-circle.score-bad{background:#ff3b3026}.period-chip{border:1px solid var(--border-glass);background:var(--surface-glass);color:var(--text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:20px;padding:6px 16px;font-size:14px;transition:all .2s}.period-chip--active{background:var(--accent);color:#fff;border-color:var(--accent)}
