*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#080808;--bg-card:#121212;--bg-elevated:#1a1a1a;--primary:#0f0;--primary-dim:#00ff0026;--primary-glow:#00ff004d;--text:#fff;--text-secondary:#888;--text-muted:#555;--danger:#f44;--warning:#fa0;--info:#0af;--border:#222;--radius:16px;--radius-sm:10px}html,body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;font-family:DM Sans,sans-serif;overflow-x:hidden}#root{flex-direction:column;max-width:100%;min-height:100dvh;margin:0 auto;display:flex}input,textarea,select,button{font-family:DM Sans,sans-serif}a{color:var(--primary);text-decoration:none}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:2px}.splash{z-index:9999;background:#000;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.splash-content{flex-direction:column;align-items:center;gap:24px;display:flex}.splash-logo{object-fit:contain;width:200px;height:auto;animation:1.5s ease-in-out infinite splash-glow}@keyframes splash-glow{0%,to{filter:drop-shadow(0 0 16px #00ff004d)}50%{filter:drop-shadow(0 0 40px #00ff00b3)drop-shadow(0 0 80px #00ff0040)}}.splash-loader-track{background:#ffffff1a;border-radius:2px;width:160px;height:3px;overflow:hidden}.splash-loader-fill{transform-origin:0;background:#0f0;border-radius:2px;width:100%;height:100%;box-shadow:0 0 12px #00ff0080}.splash-subtitle{color:#fff;letter-spacing:3px;text-transform:uppercase;font-size:13px;font-weight:500}.app-header{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(20px);background:#080808d9;justify-content:center;align-items:center;padding:14px 16px 10px;display:flex}.header-logo{object-fit:contain;filter:drop-shadow(0 0 6px #00ff0040);max-width:120px;height:auto}.bottom-nav{width:100%;max-width:480px;padding:8px 0;padding-bottom:max(8px, env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);z-index:100;background:#080808d9;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-item{color:var(--text-muted);border-radius:12px;flex-direction:column;align-items:center;gap:4px;padding:6px 10px;font-size:11px;font-weight:500;text-decoration:none;transition:color .2s;display:flex}.nav-item.active{color:var(--primary)}.nav-item.active svg{filter:drop-shadow(0 0 8px var(--primary-glow))}.calorie-ring-wrapper{width:220px;height:220px;margin:0 auto;position:relative}.calorie-ring-svg{width:100%;height:100%}.calorie-ring-text{text-align:center;flex-direction:column;gap:2px;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.calorie-ring-number{color:var(--text);font-size:40px;font-weight:700;line-height:1}.calorie-ring-label{color:var(--text-secondary);font-size:13px;font-weight:500}.macro-bar{flex-direction:column;gap:6px;display:flex}.macro-bar-header{justify-content:space-between;align-items:baseline;display:flex}.macro-bar-label,.macro-bar-value{color:var(--text);font-size:14px;font-weight:600}.macro-bar-unit{color:var(--text-secondary);font-weight:400}.macro-bar-track{background:var(--bg-elevated);border-radius:4px;height:8px;overflow:hidden}.macro-bar-fill{border-radius:4px;height:100%}.ai-rec{flex-direction:column;gap:10px;display:flex}.ai-rec-divider{background:var(--border);height:1px;margin:4px 0 0}.ai-rec-remaining{text-align:center}.ai-rec-rem-text{color:var(--text-secondary);font-size:13px}.ai-rec-rem-text b{color:var(--text);font-weight:700}.ai-rec-cta{background:var(--primary-dim);width:100%;color:var(--primary);cursor:pointer;border:1px dashed #00ff0040;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:9px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.ai-rec-cta:hover{background:#00ff0026}.ai-rec-loading{color:var(--text-secondary);justify-content:center;align-items:center;gap:6px;padding:8px;font-size:13px;display:flex}.ai-rec-section{flex-direction:column;gap:6px;display:flex;overflow:hidden}.ai-rec-suggestions-header{justify-content:space-between;align-items:center;display:flex}.ai-rec-suggestions-title{color:var(--primary);text-transform:uppercase;letter-spacing:.3px;align-items:center;gap:4px;font-size:12px;font-weight:600;display:flex}.ai-rec-refresh{border:1px solid var(--border);background:var(--bg-elevated);width:26px;height:26px;color:var(--text-muted);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.ai-rec-refresh:hover{border-color:var(--primary);color:var(--primary)}.ai-rec-list{flex-direction:column;gap:4px;display:flex}.ai-rec-card{background:var(--bg);border:1px solid var(--border);border-radius:8px;justify-content:space-between;align-items:center;gap:8px;padding:8px 10px;display:flex}.ai-rec-card-left{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.ai-rec-card-emoji{flex-shrink:0;font-size:18px}.ai-rec-card-info{flex-direction:column;gap:0;min-width:0;display:flex}.ai-rec-card-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.ai-rec-card-macros{color:var(--text-muted);font-size:11px}.ai-rec-log-btn{border:1px solid var(--primary);width:32px;height:32px;color:var(--primary);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;transition:all .2s;display:flex}.ai-rec-log-btn:hover:not(:disabled){background:var(--primary);color:#080808}.ai-rec-log-btn.saved{background:var(--primary);color:#080808;border-color:var(--primary)}.cal-card{flex-direction:column;gap:12px;display:flex}.cal-header{justify-content:space-between;align-items:center;display:flex}.cal-month{color:var(--text);font-size:16px;font-weight:700}.cal-nav{border:1px solid var(--border);background:var(--bg-elevated);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:50%;justify-content:center;align-items:center;display:flex}.cal-nav:active{transform:scale(.92)}.cal-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.cal-day-label{color:var(--text-muted);text-align:center;padding-bottom:4px;font-size:11px;font-weight:600}.cal-cell{aspect-ratio:1;color:var(--text-secondary);background:var(--bg-elevated);cursor:pointer;-webkit-tap-highlight-color:transparent;border:1.5px solid #0000;border-radius:8px;justify-content:center;align-items:center;font-size:13px;font-weight:600;transition:border-color .15s;display:flex}.cal-cell:active{transform:scale(.92)}.cal-cell--empty{cursor:default;background:0 0}.cal-cell--today{border-color:var(--primary);color:var(--primary);font-weight:800}.cal-cell--green{color:#0f0;background:#00ff0026}.cal-cell--yellow{color:#fa0;background:#ffaa0026}.cal-cell--red{color:#f44;background:#ff444426}.cal-legend{justify-content:center;gap:16px;display:flex}.cal-legend-item{color:var(--text-muted);align-items:center;gap:5px;font-size:11px;display:flex}.cal-dot{border-radius:50%;width:8px;height:8px}.cal-dot--green{background:#0f0}.cal-dot--yellow{background:#fa0}.cal-dot--red{background:#f44}.cal-modal-bg{z-index:9000;background:#0009;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.cal-modal{background:var(--bg-card);-webkit-overflow-scrolling:touch;border-top-left-radius:20px;border-top-right-radius:20px;flex-direction:column;gap:14px;width:100%;max-width:480px;max-height:80vh;padding:20px 16px 32px;display:flex;overflow-y:auto}.cal-modal-header{justify-content:space-between;align-items:center;display:flex}.cal-modal-header h3{color:var(--text);font-size:17px;font-weight:700}.cal-modal-close{border:1px solid var(--border);background:var(--bg-elevated);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;display:flex}.cal-compare{background:var(--bg-elevated);border-radius:12px;align-items:center;gap:0;padding:12px;display:flex}.cal-compare-col{flex-direction:column;flex:1;align-items:center;gap:3px;display:flex}.cal-compare-label{color:var(--text-muted);text-transform:uppercase;font-size:11px;font-weight:600}.cal-compare-val{color:var(--text);font-size:20px;font-weight:700}.cal-compare-val--primary{color:#0f0}.cal-compare-sub{color:var(--text-secondary);font-size:11px}.cal-compare-divider{background:var(--border);flex-shrink:0;width:1px;height:40px}.cal-section{flex-direction:column;gap:6px;display:flex}.cal-section-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:700}.cal-meal{background:var(--bg);border-radius:8px;justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.cal-meal--plan{border-left:3px solid #00ff004d}.cal-meal-type{color:#0f0;text-transform:uppercase;margin-bottom:1px;font-size:10px;font-weight:600;display:block}.cal-meal-name{color:var(--text);font-size:13px;font-weight:600}.cal-meal-macros{color:var(--text-secondary);white-space:nowrap;flex-shrink:0;margin-left:8px;font-size:12px}.cal-empty{color:var(--text-muted);text-align:center;padding:12px 0;font-size:13px}.cal-modal-goto{color:#0f0;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#00ff001a;border:1px solid #00ff0040;border-radius:10px;justify-content:center;align-items:center;width:100%;padding:12px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:600;display:flex}.cal-modal-goto:active{transform:scale(.98)}.dashboard{flex-direction:column;gap:16px;display:flex}.dashboard-header{justify-content:space-between;align-items:flex-start;margin-bottom:4px;display:flex}.page-title{color:var(--text);margin-bottom:4px;font-size:28px;font-weight:700}.page-subtitle{color:var(--text-secondary);font-size:14px}.streak-badge{color:#fa0;background:#ffaa0026;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:600;display:flex}.date-nav{justify-content:center;align-items:center;gap:12px;display:flex}.date-nav-btn{background:var(--bg-card);border:1px solid var(--border);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.date-nav-btn:hover{color:var(--primary);border-color:#00ff004d}.date-nav-label{color:var(--text);cursor:pointer;text-align:center;background:0 0;border:none;border-radius:20px;justify-content:center;align-items:center;gap:4px;min-width:140px;padding:6px 16px;font-size:16px;font-weight:600;transition:all .2s;display:flex}.date-nav-label:hover{background:var(--bg-card)}.date-nav-label--today{color:var(--primary)}.date-nav-caret{color:var(--text-muted);transition:transform .3s}.date-nav-caret--open{transform:rotate(180deg)}.nudge-card{background:#00ff000a;border-color:#00ff004d;align-items:center;gap:14px;display:flex}.nudge-bruno{object-fit:cover;object-position:center top;border:2px solid #0f0;border-radius:50%;flex-shrink:0;width:52px;height:52px}.nudge-info{flex-direction:column;flex:1;gap:8px;display:flex}.nudge-text{color:var(--text);font-size:14px;font-weight:600;line-height:1.4}.nudge-btn{color:#080808;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#0f0;border:none;border-radius:10px;justify-content:center;align-items:center;width:100%;padding:10px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:700;display:flex}.nudge-btn:active{transform:scale(.97)}.week-card{padding:0;overflow:hidden}.week-header{cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:14px 16px;display:flex}.week-icon{color:var(--primary);flex-shrink:0}.week-summary{scrollbar-width:none;flex:1;align-items:center;gap:4px;display:flex;overflow-x:auto}.week-summary::-webkit-scrollbar{display:none}.week-stat{color:var(--text-secondary);white-space:nowrap;font-size:12px;font-weight:600}.week-stat--streak{color:var(--text)}.week-sep{color:var(--text-muted);font-size:10px}.week-trend{flex-shrink:0;align-items:center;display:flex}.week-trend--up{color:#0f0}.week-trend--down{color:#f44}.week-caret{color:var(--text-muted);flex-shrink:0;transition:transform .3s}.week-caret--open{transform:rotate(180deg)}.week-detail{border-top:1px solid var(--border);overflow:hidden}.week-detail-grid{grid-template-columns:repeat(4,1fr);gap:4px;padding:14px 16px;display:grid}.week-detail-item{background:var(--bg-elevated);border-radius:8px;flex-direction:column;align-items:center;gap:2px;padding:8px 2px;display:flex}.week-detail-val{color:var(--text);font-size:18px;font-weight:700}.week-detail-sub{color:var(--text-muted);font-size:13px;font-weight:400}.week-detail-lbl{color:var(--text-secondary);text-align:center;font-size:10px;font-weight:500}.week-trend-detail{align-items:center;gap:6px;padding:10px 16px 14px;font-size:12px;font-weight:500;display:flex}.week-trend-detail--up{color:#0f0}.week-trend-detail--down{color:#f44}.water-card{flex-direction:column;gap:10px;display:flex}.water-row{align-items:center;gap:12px;display:flex}.water-icon{color:#0af;flex-shrink:0}.water-info{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.water-count{align-items:baseline;gap:4px;display:flex}.water-val{color:var(--text);font-size:18px;font-weight:700}.water-goal{color:var(--text-muted);font-size:13px}.water-bar{background:var(--bg-elevated);border-radius:3px;height:6px;overflow:hidden}.water-fill{background:#0af;border-radius:3px;height:100%;transition:width .3s}.water-remaining{color:var(--text-secondary);font-size:11px}.water-done{color:#0f0;font-size:11px;font-weight:600}.water-btns{flex-shrink:0;gap:6px;display:flex}.water-btn{border:1px solid var(--border);background:var(--bg-elevated);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.water-btn:disabled{opacity:.25;cursor:not-allowed}.water-btn--add{color:#0af;border-color:#0af}.water-btn--add:active{background:#00aaff1a;transform:scale(.9)}.water-btn:first-child:active{transform:scale(.9)}.water-hint{color:#0af;background:#00aaff0f;border:1px solid #0af3;border-radius:10px;align-items:center;gap:8px;padding:8px 10px;font-size:13px;font-weight:500;display:flex}.water-hint-bruno{object-fit:cover;object-position:center top;border:1.5px solid #0af;border-radius:50%;flex-shrink:0;width:28px;height:28px}.card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);padding:20px}.card-title{color:var(--text);align-items:center;gap:8px;margin-bottom:16px;font-size:16px;font-weight:600;display:flex}.calorie-card{flex-direction:column;align-items:center;gap:20px;display:flex}.calorie-summary{justify-content:center;align-items:center;gap:24px;width:100%;display:flex}.calorie-stat{flex-direction:column;align-items:center;gap:2px;display:flex}.stat-value{color:var(--text);font-size:20px;font-weight:700}.stat-label{color:var(--text-secondary);font-size:12px}.calorie-divider{background:var(--border);width:1px;height:36px}.macros-grid{flex-direction:column;gap:14px;display:flex}.plan-today-card .card-title{align-items:center;gap:8px;display:flex}.plan-today-list{flex-direction:column;gap:6px;margin-top:10px;display:flex}.plan-today-item{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:0;padding:0;transition:border-color .2s;display:flex;overflow:hidden}.plan-today-row{align-items:center;gap:10px;padding:12px;display:flex}.plan-today-item--logged{opacity:.45;border-color:#0f03}.plan-today-item--skipped{opacity:.3}.plan-today-info{cursor:pointer;-webkit-tap-highlight-color:transparent;flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.plan-today-type{color:var(--primary);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:600}.plan-today-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.plan-today-macros{color:var(--text-muted);font-size:11px}.plan-today-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.plan-today-log-btn{background:var(--primary);color:#080808;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:8px;align-items:center;gap:4px;padding:8px 12px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:700;display:flex}.plan-today-log-btn:active{transform:scale(.95)}.plan-today-skip-btn{border:1px solid var(--border);width:34px;height:34px;color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.plan-today-skip-btn:hover{border-color:var(--danger);color:var(--danger)}.plan-today-done{width:32px;height:32px;color:var(--primary);cursor:pointer;-webkit-tap-highlight-color:transparent;background:#00ff001f;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .2s;display:flex}.plan-today-done:hover{background:#00ff0040}.plan-today-skipped-label{color:var(--text-muted);font-size:11px;font-style:italic}.plan-today-chevron{color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;flex-shrink:0;transition:transform .3s}.plan-today-chevron.open{transform:rotate(180deg)}.plan-today-hide-btn{width:28px;height:28px;color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:color .2s;display:flex}.plan-today-hide-btn:hover{color:var(--danger)}.plan-today-detail{border-top:1px solid var(--border);flex-direction:column;gap:10px;padding:0 12px;display:flex;overflow:hidden}.plan-detail-macros{grid-template-columns:repeat(4,1fr);gap:6px;padding-top:12px;display:grid}.plan-detail-macro{background:var(--bg);border-radius:8px;flex-direction:column;align-items:center;gap:1px;padding:8px 4px;display:flex}.plan-detail-macro-val{color:var(--text);font-size:15px;font-weight:700}.plan-detail-macro-lbl{color:var(--text-secondary);font-size:10px}.plan-detail-desc{color:var(--text-secondary);font-size:13px;line-height:1.5}.plan-detail-section{flex-direction:column;gap:4px;padding-bottom:12px;display:flex}.plan-detail-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:700}.plan-detail-ingredients{flex-direction:column;gap:2px;list-style:none;display:flex}.plan-detail-ingredients li{color:var(--text);border-bottom:1px solid #2226;padding:4px 0;font-size:13px}.plan-detail-ingredients li:last-child{border-bottom:none}.plan-today-item--ready{background:#00ff000a;border-color:#0f0}.plan-today-item--missing{background:#ff444408;border-color:#f44}.shop-fab{z-index:7000;background:var(--bg-card);color:#0f0;cursor:pointer;-webkit-tap-highlight-color:transparent;border:1.5px solid #0f0;border-radius:24px;align-items:center;gap:6px;padding:10px 16px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:700;transition:transform .2s;display:flex;position:fixed;bottom:80px;left:16px;box-shadow:0 4px 16px #00ff0026,0 2px 8px #0006}.shop-fab:active{transform:scale(.95)}.shop-overlay{z-index:9500;background:var(--bg);-webkit-overflow-scrolling:touch;position:fixed;inset:0;overflow-y:auto}.shop-overlay-inner{max-width:480px;min-height:100vh;margin:0 auto;padding:0 16px 40px}.shop-overlay-header{background:var(--bg);z-index:10;justify-content:space-between;align-items:center;padding:20px 0 16px;display:flex;position:sticky;top:0}.shop-overlay-header h2{color:var(--text);font-size:20px;font-weight:700}.shop-overlay-close{border:1px solid var(--border);background:var(--bg-elevated);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.shop-overlay-body{flex-direction:column;gap:16px;display:flex}.shop-cat{flex-direction:column;gap:2px;display:flex}.shop-cat-title{color:#0f0;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);padding-bottom:6px;font-size:12px;font-weight:700}.shop-item{cursor:pointer;-webkit-tap-highlight-color:transparent;border-bottom:1px solid #22222280;align-items:flex-start;gap:10px;padding:10px 0;display:flex}.shop-item:last-child{border-bottom:none}.shop-item input[type=checkbox]{accent-color:#0f0;flex-shrink:0;width:20px;height:20px;margin-top:1px}.shop-item-info{flex-direction:column;flex:1;gap:2px;display:flex}.shop-item-name{color:var(--text);font-size:14px}.shop-item-name b{font-weight:700}.shop-item.checked .shop-item-name{color:var(--text-muted);text-decoration:line-through}.shop-item.pantry .shop-item-name{color:var(--text-secondary)}.shop-pantry-badge{color:var(--info);background:#00aaff1f;border-radius:4px;margin-left:6px;padding:1px 5px;font-size:9px;font-weight:600;display:inline-block}.shop-item-used{color:var(--text-muted);font-size:11px}.meal-list{flex-direction:column;gap:0;display:flex}.meal-group{flex-direction:column;display:flex}.meal-group-label{color:var(--text-secondary);border-bottom:1px solid var(--border);padding:8px 0 4px;font-size:12px;font-weight:600}.meal-group:first-child .meal-group-label{padding-top:0}.meal-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 0;display:flex}.meal-item:last-child{border-bottom:none;padding-bottom:0}.meal-item:first-child{padding-top:0}.meal-info{flex-direction:column;gap:2px;display:flex}.meal-name{color:var(--text);font-size:14px;font-weight:500}.meal-time{color:var(--text-muted);font-size:12px}.meal-actions,.meal-macros-mini{align-items:center;gap:10px;display:flex}.meal-delete-btn{border:1px solid var(--border);width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:flex}.meal-delete-btn:hover{color:#f44;background:#ff44441a;border-color:#ff44444d}.meal-delete-btn--confirm{color:#f44;background:#ff444426;border-color:#f44;animation:.6s ease-in-out infinite alternate pulse-delete}@keyframes pulse-delete{0%{box-shadow:0 0 #ff44444d}to{box-shadow:0 0 8px 2px #f443}}.meal-cal{color:var(--primary);font-size:14px;font-weight:600}.meal-protein{color:var(--text-secondary);font-size:12px}.stat-value--active{color:var(--primary);font-size:18px}.activity-card{overflow:hidden}.activity-header{justify-content:space-between;align-items:center;display:flex}.activity-header .card-title{margin-bottom:0}.health-connect-btn{background:var(--primary-dim);color:var(--primary);cursor:pointer;border:1px solid #0f03;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:600;transition:all .2s;display:flex}.health-connect-btn:hover{background:var(--primary-glow)}.activity-grid{grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px;display:grid}.activity-item{background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border);flex-direction:column;align-items:center;gap:10px;padding:14px 8px;display:flex}.activity-icon{border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.activity-icon--steps{color:#0af;background:#00aaff26}.activity-icon--burn{background:var(--primary-dim);color:var(--primary)}.activity-icon--tdee{color:#fa0;background:#ffaa0026}.activity-detail{flex-direction:column;align-items:center;gap:2px;display:flex}.activity-value{color:var(--text);font-size:18px;font-weight:700}.activity-label{color:var(--text-secondary);text-align:center;font-size:11px}.activity-connect-hint{border-radius:var(--radius-sm);width:100%;color:var(--text-secondary);cursor:pointer;background:0 0;border:1px dashed #0f03;justify-content:center;align-items:center;gap:8px;margin-top:12px;padding:10px;font-size:12px;transition:all .2s;display:flex}.activity-connect-hint:hover{color:var(--primary);border-color:var(--primary);background:var(--primary-dim)}.health-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000000b3;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.health-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:20px 20px 0 0;width:100%;max-width:480px;max-height:85vh;overflow-y:auto}.health-modal-header{background:var(--bg-card);z-index:1;justify-content:space-between;align-items:center;padding:20px 20px 0;display:flex;position:sticky;top:0}.health-modal-header h2{color:var(--text);font-size:20px;font-weight:700}.health-modal-close{background:var(--bg-elevated);border:1px solid var(--border);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.health-modal-close:hover{color:var(--text);background:var(--border)}.health-modal-body{padding:20px}.health-modal-intro{color:var(--text-secondary);margin-bottom:20px;font-size:14px;line-height:1.6}.health-steps{flex-direction:column;gap:20px;display:flex}.health-step{gap:14px;display:flex}.health-step-num{background:var(--primary);color:#000;border-radius:50%;justify-content:center;align-items:center;width:28px;min-width:28px;height:28px;font-size:14px;font-weight:700;display:flex}.health-step-content h3{color:var(--text);margin-bottom:6px;font-size:15px;font-weight:600}.health-step-content p{color:var(--text-secondary);font-size:13px;line-height:1.5}.health-code-block{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);margin-top:10px;padding:12px}.health-code-line{color:var(--text-secondary);font-family:SF Mono,Fira Code,monospace;font-size:11px;line-height:1.8}.health-highlight{color:var(--primary);font-weight:500}.health-list{margin-top:8px;padding:0;list-style:none}.health-list li{color:var(--text-secondary);margin-bottom:4px;padding-left:16px;font-size:13px;line-height:1.5;position:relative}.health-list li:before{content:"";background:var(--primary);border-radius:50%;width:6px;height:6px;position:absolute;top:8px;left:0}.health-modal-note{background:var(--primary-dim);border-radius:var(--radius-sm);color:var(--primary);border:1px solid #00ff0026;align-items:flex-start;gap:10px;margin-top:24px;padding:14px;font-size:13px;line-height:1.5;display:flex}.health-modal-note svg{min-width:16px;margin-top:2px}.health-modal-download{background:var(--primary);color:#000;border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:10px;width:100%;margin-bottom:24px;padding:14px;font-family:inherit;font-size:16px;font-weight:700;text-decoration:none;transition:all .2s;display:flex;box-shadow:0 0 24px #00ff004d}.health-modal-download:hover{box-shadow:0 0 32px #00ff0073}.health-modal-details{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-secondary);cursor:pointer;background:0 0;justify-content:center;align-items:center;gap:6px;margin-top:20px;padding:12px;font-size:13px;text-decoration:none;transition:all .2s;display:flex}.health-modal-details:hover{color:var(--primary);border-color:#00ff004d}.vr-overlay{z-index:9000;background:#000000b3;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.vr-modal{background:var(--bg-card);border-top-left-radius:24px;border-top-right-radius:24px;flex-direction:column;width:100%;max-width:480px;min-height:50vh;padding:20px 20px 40px;display:flex;position:relative}.vr-close{border:1px solid var(--border);background:var(--bg-elevated);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;z-index:1;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:16px;right:16px}.vr-close:hover{border-color:var(--danger);color:var(--danger)}.vr-content{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:24px;display:flex}.vr-rec-indicator{align-items:center;gap:8px;display:flex}.vr-rec-dot{background:#ff3b30;border-radius:50%;width:10px;height:10px;animation:1s ease-in-out infinite vr-blink}@keyframes vr-blink{0%,to{opacity:1}50%{opacity:.15}}.vr-rec-label{color:#ff3b30;text-transform:uppercase;letter-spacing:1px;font-size:13px;font-weight:600}.vr-timer{font-variant-numeric:tabular-nums;color:var(--text);font-size:48px;font-weight:700}.vr-waveform{justify-content:center;align-items:center;gap:2.5px;width:100%;height:56px;padding:0 8px;display:flex}.vr-bar{background:#0f0;border-radius:1.5px;width:3px;min-height:3px;transition:height 80ms linear;box-shadow:0 0 6px #00ff004d}.vr-transcript{color:var(--text-secondary);text-align:center;min-height:22px;max-height:60px;padding:0 16px;font-size:15px;overflow:hidden}.vr-stop-btn{background:var(--primary);color:#080808;border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;margin-top:8px;padding:14px 40px;font-size:15px;font-weight:600;transition:transform .1s;display:flex}.vr-stop-btn:active{transform:scale(.96)}.food-search{flex-direction:column;gap:0;display:flex;position:relative}.food-search-input-wrap{align-items:center;display:flex;position:relative}.food-search-icon{color:var(--text-muted);pointer-events:none;position:absolute;left:12px}.food-search-spinner{color:var(--primary);position:absolute;right:12px}.food-search-input{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);border-radius:8px;outline:none;padding:11px 34px 11px 36px;font-size:14px;transition:border-color .2s}.food-search-input:focus{border-color:var(--primary)}.food-search-input::placeholder{color:var(--text-muted)}.food-search-results{background:var(--bg-card);border:1px solid var(--border);border-top:none;border-radius:0 0 8px 8px;flex-direction:column;max-height:260px;display:flex;overflow-y:auto}.food-search-item{border:none;border-bottom:1px solid var(--border);color:var(--text);cursor:pointer;text-align:left;background:0 0;align-items:center;gap:10px;padding:10px 12px;transition:background .15s;display:flex}.food-search-item:last-child{border-bottom:none}.food-search-item:hover,.food-search-item:active{background:var(--bg-elevated)}.food-search-emoji{flex-shrink:0;font-size:18px}.food-search-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.food-search-name{flex-wrap:wrap;align-items:center;gap:4px;font-size:14px;font-weight:600;display:flex}.food-search-brand{color:var(--text-muted);font-size:12px;font-weight:400}.food-search-badge{border-radius:4px;justify-content:center;align-items:center;padding:1px 5px;font-size:9px;font-weight:700;line-height:1.2;display:inline-flex}.food-search-badge.verified{color:var(--primary);background:#00ff0026}.food-search-meta{color:var(--text-muted);font-size:11px}.food-search-meta i{color:var(--text-muted);font-style:normal}.food-search-add{color:var(--primary);flex-shrink:0}.rc-overlay{z-index:9000;background:#000000b3;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.rc-modal{background:var(--bg-card);border-top-left-radius:24px;border-top-right-radius:24px;flex-direction:column;width:100%;max-width:480px;max-height:90vh;display:flex;overflow:hidden}.rc-top-bar{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px 12px;display:flex}.rc-title{color:var(--text);font-size:17px;font-weight:700}.rc-close{border:1px solid var(--border);background:var(--bg-elevated);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;display:flex}.rc-body{flex-direction:column;flex:1;gap:14px;padding:16px 20px;display:flex;overflow-y:auto}.rc-name-row{gap:8px;display:flex}.rc-emoji-input{text-align:center;background:var(--bg-elevated);border:1px solid var(--border);width:48px;height:44px;color:var(--text);border-radius:8px;outline:none;flex-shrink:0;font-size:20px}.rc-emoji-input:focus{border-color:var(--primary)}.rc-name-input{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text);border-radius:8px;outline:none;flex:1;padding:10px 14px;font-size:15px;font-weight:600}.rc-name-input:focus{border-color:var(--primary)}.rc-name-input::placeholder{color:var(--text-muted)}.rc-ingredients{border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:0;display:flex;overflow:hidden}.rc-ing-row{border-bottom:1px solid var(--border);align-items:center;gap:6px;padding:8px 10px;display:flex}.rc-ing-row:last-of-type{border-bottom:none}.rc-ing-emoji{flex-shrink:0;font-size:16px}.rc-ing-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:13px;font-weight:500;overflow:hidden}.rc-ing-amount{background:var(--bg);border:1px solid var(--border);width:52px;color:var(--text);text-align:center;-moz-appearance:textfield;border-radius:6px;outline:none;flex-shrink:0;padding:6px 4px;font-size:13px;font-weight:600}.rc-ing-amount:focus{border-color:var(--primary)}.rc-ing-unit-wrap{flex-shrink:0;position:relative}.rc-ing-unit{background:var(--bg);border:1px solid var(--border);color:var(--text);cursor:pointer;appearance:none;border-radius:6px;outline:none;padding:6px 20px 6px 6px;font-size:12px}.rc-ing-unit-arrow{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;right:4px;transform:translateY(-50%)}.rc-ing-kcal{color:var(--primary);text-align:right;flex-shrink:0;min-width:32px;font-size:12px;font-weight:600}.rc-ing-del{width:24px;height:24px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.rc-ing-del:hover{color:var(--danger)}.rc-totals{background:var(--bg-elevated);align-items:center;gap:8px;padding:10px;display:flex}.rc-totals-label{color:var(--text);flex:1;font-size:13px;font-weight:700}.rc-totals-kcal{color:var(--primary);font-size:14px;font-weight:700}.rc-totals-macro{color:var(--text-secondary);font-size:11px}.rc-footer{border-top:1px solid var(--border);flex-shrink:0;padding:12px 20px 28px}.rc-save-btn{background:var(--primary);color:#080808;border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px;font-size:15px;font-weight:600;display:flex}.rc-save-btn:disabled{opacity:.4;cursor:not-allowed}.rc-save-btn:active:not(:disabled){transform:scale(.98)}.fc-overlay{z-index:9000;background:#000000b3;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.fc-modal{background:var(--bg-card);border-top-left-radius:24px;border-top-right-radius:24px;flex-direction:column;width:100%;max-width:480px;max-height:92vh;display:flex;overflow:hidden}.fc-top-bar{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px 12px;display:flex}.fc-title{color:var(--text);font-size:17px;font-weight:700}.fc-close{border:1px solid var(--border);background:var(--bg-elevated);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;display:flex}.fc-body{flex-direction:column;flex:1;align-items:center;gap:16px;padding:16px 20px 32px;display:flex;overflow-y:auto}.fc-viewfinder{aspect-ratio:4/3;background:#000;border-radius:16px;width:100%;position:relative;overflow:hidden}.fc-video{object-fit:cover;width:100%;height:100%}.fc-guide{pointer-events:none;border:2px dashed #00ff004d;border-radius:12px;position:absolute;inset:12px}.fc-controls{justify-content:center;align-items:center;gap:32px;padding:8px 0;display:flex}.fc-gallery-btn{border:1px solid var(--border);background:var(--bg-elevated);width:44px;height:44px;color:var(--text-secondary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.fc-gallery-btn:hover{border-color:var(--primary);color:var(--primary)}.fc-shutter{border:3px solid var(--primary);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;width:68px;height:68px;padding:4px;transition:transform .1s;display:flex}.fc-shutter:active{transform:scale(.92)}.fc-shutter-inner{background:var(--primary);border-radius:50%;width:100%;height:100%;transition:opacity .15s}.fc-shutter:hover .fc-shutter-inner{opacity:.85}.fc-spacer{width:44px}.fc-hint{color:var(--text-muted);text-align:center;font-size:13px}.fc-preview-wrap{background:#000;border-radius:16px;width:100%;overflow:hidden}.fc-preview-img{width:100%;display:block}.fc-preview-actions{gap:10px;width:100%;display:flex}.fc-retake-btn{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;flex:1;justify-content:center;align-items:center;gap:6px;padding:14px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.fc-retake-btn:hover{border-color:var(--text-secondary);color:var(--text)}.fc-confirm-btn{background:var(--primary);border-radius:var(--radius-sm);color:#080808;cursor:pointer;border:none;flex:1;justify-content:center;align-items:center;gap:6px;padding:14px;font-size:14px;font-weight:600;display:flex}.fc-confirm-btn:active{transform:scale(.98)}.log-meal{flex-direction:column;gap:16px;display:flex}.log-meal header{margin-bottom:0}.meal-cats{gap:6px;display:flex}.meal-cat{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:4px;padding:9px 4px;font-size:12px;font-weight:500;transition:all .2s;display:flex}.meal-cat.active{background:var(--primary-dim);border-color:var(--primary);color:var(--primary);font-weight:600}.mode-toggle{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:3px;display:flex}.mode-toggle-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:9px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px 12px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.mode-toggle-btn.active{background:var(--primary-dim);color:var(--primary);font-weight:600}.search-mode{flex-direction:column;gap:12px;display:flex}.search-bar{flex-direction:column;gap:0;padding:12px;display:flex}.search-input-row{align-items:center;gap:8px;display:flex}.search-input-wrap{flex:1;align-items:center;display:flex;position:relative}.search-input-icon{color:var(--text-muted);pointer-events:none;position:absolute;left:14px}.search-input{background:var(--bg-elevated);border:1px solid var(--border);width:100%;color:var(--text);border-radius:12px;outline:none;padding:14px 40px 14px 44px;font-size:16px;font-weight:500;transition:border-color .2s}.search-input::placeholder{color:var(--text-muted);font-weight:400}.search-input-spinner{color:var(--primary);position:absolute;right:14px}.search-scan-btn{background:var(--bg-elevated);border:1px solid var(--border);width:48px;height:48px;color:var(--text-secondary);cursor:pointer;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:flex}.search-scan-btn:hover,.search-scan-btn:active{border-color:var(--primary);color:var(--primary)}.search-results{border-top:1px solid var(--border);flex-direction:column;max-height:320px;margin-top:4px;display:flex;overflow-y:auto}.search-result-item{border:none;border-bottom:1px solid var(--border);color:var(--text);cursor:pointer;text-align:left;background:0 0;align-items:center;gap:12px;padding:12px 4px;transition:background .15s;display:flex}.search-result-item:last-child{border-bottom:none}.search-result-item:hover,.search-result-item:active{background:var(--bg-elevated)}.search-result-emoji{text-align:center;flex-shrink:0;width:32px;font-size:22px}.search-result-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.search-result-name{flex-wrap:wrap;align-items:center;gap:5px;font-size:14px;font-weight:600;display:flex}.search-result-brand{color:var(--text-muted);font-size:12px;font-weight:400}.search-result-badge{color:var(--primary);background:#00ff0026;border-radius:4px;padding:1px 5px;font-size:9px;font-weight:700;display:inline-flex}.search-result-meta{color:var(--text-secondary);font-size:12px}.search-result-add{color:var(--primary);flex-shrink:0}.amount-editor{flex-direction:column;gap:14px;display:flex}.amount-editor-header{align-items:center;gap:10px;display:flex}.amount-editor-emoji{flex-shrink:0;font-size:28px}.amount-editor-name-wrap{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.amount-editor-name{color:var(--text);font-size:17px;font-weight:700}.amount-editor-brand{color:var(--text-muted);font-size:13px}.amount-editor-close{border:1px solid var(--border);background:var(--bg-elevated);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:flex}.amount-editor-close:hover{border-color:var(--text-secondary);color:var(--text)}.amount-editor-row{gap:8px;display:flex}.amount-editor-input-wrap{flex:1}.amount-editor-input{background:var(--bg-elevated);border:1px solid var(--border);width:100%;color:var(--text);text-align:center;-moz-appearance:textfield;border-radius:10px;outline:none;padding:14px 16px;font-size:20px;font-weight:700;transition:border-color .2s}.amount-editor-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.amount-editor-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.amount-editor-input:focus{border-color:var(--primary)}.amount-editor-unit-wrap{flex:0 0 100px;position:relative}.amount-editor-unit{background:var(--bg-elevated);border:1px solid var(--border);width:100%;height:100%;color:var(--text);cursor:pointer;appearance:none;border-radius:10px;outline:none;padding:14px 28px 14px 14px;font-size:15px;font-weight:500}.amount-editor-unit:focus{border-color:var(--primary)}.amount-editor-unit-arrow{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.amount-presets{flex-wrap:wrap;gap:6px;display:flex}.amount-preset{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:8px;padding:7px 12px;font-size:13px;font-weight:500;transition:all .2s}.amount-preset.active{background:var(--primary-dim);border-color:var(--primary);color:var(--primary);font-weight:600}.amount-preset:hover{border-color:var(--primary)}.amount-macros{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.amount-macro{background:var(--bg-elevated);border-radius:10px;flex-direction:column;align-items:center;gap:2px;padding:10px 4px;display:flex}.amount-macro.primary{background:var(--primary-dim)}.amount-macro.primary .amount-macro-val{color:var(--primary)}.amount-macro-val{color:var(--text);font-size:18px;font-weight:700}.amount-macro-label{color:var(--text-secondary);font-size:11px;font-weight:500}.amount-save-btn{background:var(--primary);color:#080808;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px;font-size:16px;font-weight:700;transition:all .3s;display:flex}.amount-save-btn:active{transform:scale(.98)}.amount-save-btn:disabled{opacity:.5;cursor:not-allowed}.amount-save-btn.saved{background:var(--bg-elevated);color:var(--primary);border:1px solid var(--primary)}.ai-mode,.ai-input-card{flex-direction:column;gap:12px;display:flex}.ai-badge{color:var(--primary);background:var(--primary-dim);border-radius:20px;align-items:center;gap:6px;width:fit-content;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.ai-textarea{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);resize:none;outline:none;padding:14px;font-size:15px;transition:border-color .2s}.ai-textarea:focus{border-color:var(--primary)}.ai-textarea::placeholder{color:var(--text-muted)}.ai-tools{justify-content:center;gap:12px;display:flex}.ai-tool-btn{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;flex-direction:column;flex:1;align-items:center;gap:4px;max-width:110px;padding:10px 16px;transition:all .2s;display:flex}.ai-tool-btn span{font-size:11px;font-weight:500}.ai-tool-btn:hover{border-color:var(--primary);color:var(--primary)}.ai-analyze-btn{background:var(--primary);color:#080808;border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px;font-size:15px;font-weight:600;transition:opacity .2s,transform .1s;display:flex}.ai-analyze-btn:active{transform:scale(.98)}.ai-analyze-btn:disabled{opacity:.5;cursor:not-allowed}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.qty-editor{flex-direction:column;gap:12px;display:flex}.qty-header{justify-content:space-between;align-items:center;display:flex}.qty-title{color:var(--text);font-size:17px;font-weight:700}.qty-back{border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;border-radius:20px;align-items:center;gap:4px;padding:6px 12px;font-size:13px;transition:all .2s;display:flex}.qty-back:hover{border-color:var(--text-secondary);color:var(--text)}.qty-items{flex-direction:column;gap:8px;display:flex}.qty-item{flex-direction:column;gap:10px;padding:14px;display:flex}.qty-item-top{align-items:center;gap:8px;display:flex}.qty-emoji{flex-shrink:0;font-size:20px}.qty-name{color:var(--text);flex:1;font-size:15px;font-weight:600}.qty-remove{width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:color .2s;display:flex}.qty-remove:hover{color:var(--danger)}.qty-item-controls{align-items:center;gap:8px;display:flex}.qty-amount-wrap{flex:0 0 72px}.qty-amount{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);text-align:center;-moz-appearance:textfield;border-radius:8px;outline:none;padding:10px 12px;font-size:16px;font-weight:600;transition:border-color .2s}.qty-amount::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.qty-amount::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.qty-amount:focus{border-color:var(--primary)}.qty-unit-wrap{flex:0 0 90px;position:relative}.qty-unit{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);cursor:pointer;appearance:none;border-radius:8px;outline:none;padding:10px 28px 10px 12px;font-size:14px;font-weight:500;transition:border-color .2s}.qty-unit:focus{border-color:var(--primary)}.qty-unit-arrow{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.qty-kcal{text-align:right;color:var(--primary);white-space:nowrap;flex:1;font-size:16px;font-weight:700}.qty-macros{gap:12px;padding-left:28px;display:flex}.qty-macro{color:var(--text-secondary);font-size:12px}.qty-macro b{color:var(--text);font-weight:600}.qty-totals{padding:14px}.qty-totals-grid{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.qty-total-item{background:var(--bg-elevated);border-radius:8px;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;display:flex}.qty-total-item.primary{background:var(--primary-dim)}.qty-total-item.primary .qty-total-val{color:var(--primary)}.qty-total-val{color:var(--text);font-size:18px;font-weight:700}.qty-total-label{color:var(--text-secondary);font-size:11px;font-weight:500}.qty-actions{flex-direction:column;gap:8px;display:flex}.save-button{background:var(--primary);color:#080808;border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px;font-size:15px;font-weight:700;transition:all .3s;display:flex}.save-button:active{transform:scale(.98)}.save-button.saved{background:var(--bg-elevated);color:var(--primary);border:1px solid var(--primary)}.recipe-save-btn{width:100%;color:var(--text-secondary);border:1px dashed var(--border);border-radius:var(--radius-sm);cursor:pointer;background:0 0;justify-content:center;align-items:center;gap:6px;padding:12px;font-size:14px;transition:all .2s;display:flex}.recipe-save-btn:hover{border-color:var(--primary);color:var(--primary)}.recipe-create-inline{flex-direction:column;gap:8px;display:flex;overflow:hidden}.recipe-create-row{gap:8px;display:flex}.recipe-emoji-input{text-align:center;background:var(--bg-elevated);border:1px solid var(--border);width:48px;height:44px;color:var(--text);border-radius:8px;outline:none;flex-shrink:0;font-size:20px}.recipe-emoji-input:focus{border-color:var(--primary)}.recipe-name-input{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text);border-radius:8px;outline:none;flex:1;padding:10px 14px;font-size:15px}.recipe-name-input:focus{border-color:var(--primary)}.recipe-name-input::placeholder{color:var(--text-muted)}.recipe-create-actions{gap:8px;display:flex}.recipe-confirm-btn{background:var(--primary);color:#080808;cursor:pointer;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px;font-size:14px;font-weight:600;display:flex}.recipe-confirm-btn:disabled{opacity:.4;cursor:not-allowed}.recipe-cancel-btn{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;border-radius:8px;padding:10px 16px;font-size:14px}.scanner-overlay-bg{z-index:9000;background:#000000b3;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.scanner-modal{background:var(--bg-card);border-top-left-radius:24px;border-top-right-radius:24px;flex-direction:column;width:100%;max-width:480px;min-height:60vh;padding:20px 20px 40px;display:flex;position:relative}.scanner-close{border:1px solid var(--border);background:var(--bg-elevated);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;z-index:1;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:16px;right:16px}.scanner-close:hover{border-color:var(--danger);color:var(--danger)}.scanner-modal-content{flex-direction:column;flex:1;align-items:center;gap:16px;padding-top:8px;display:flex}.scanner-viewport{aspect-ratio:3/4;border-radius:var(--radius-sm);background:#000;width:100%;position:relative;overflow:hidden}.scanner-video{object-fit:cover;width:100%;height:100%}.scanner-guide{border:2px solid var(--primary);width:80%;height:30%;box-shadow:0 0 0 2000px #00000073, 0 0 24px var(--primary-glow);pointer-events:none;border-radius:8px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.scanner-guide:after{content:"";background:var(--primary);height:2px;box-shadow:0 0 8px var(--primary);animation:2s ease-in-out infinite scan-line;position:absolute;top:0;left:0;right:0}@keyframes scan-line{0%,to{top:0}50%{top:calc(100% - 2px)}}.scanner-hint{color:var(--text-secondary);text-align:center;font-size:13px}.scan-error{border:1px solid var(--danger);color:var(--danger);text-align:center;cursor:pointer;background:#ff44441a;font-size:14px}.my-recipes{flex-direction:column;gap:12px;display:flex}.my-recipes-header{justify-content:space-between;align-items:center;display:flex}.my-recipes-add-btn{background:var(--primary-dim);color:var(--primary);cursor:pointer;border:1px solid #0000;border-radius:20px;align-items:center;gap:4px;padding:6px 12px;font-size:12px;font-weight:600;transition:all .2s;display:flex}.my-recipes-add-btn:hover{border-color:var(--primary)}.my-recipes-empty{color:var(--text-muted);text-align:center;padding:8px 0;font-size:13px}.my-recipes-grid{flex-direction:column;gap:6px;display:flex}.recipe-tile{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text);text-align:left;align-items:center;gap:10px;padding:12px 14px;transition:border-color .2s;display:flex}.recipe-tile:hover{border-color:var(--primary)}.recipe-tile-emoji{flex-shrink:0;font-size:20px}.recipe-tile-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.recipe-tile-name{font-size:14px;font-weight:600}.recipe-tile-meta{color:var(--text-secondary);font-size:12px}.recipe-tile-delete{width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;transition:color .2s;display:flex}.recipe-tile-delete:hover{color:var(--danger)}.quick-add{flex-direction:column;gap:12px;display:flex}.quick-items{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}.quick-item{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text);flex-direction:column;align-items:center;gap:4px;padding:14px 8px;transition:border-color .2s;display:flex}.quick-item:hover{border-color:var(--primary)}.quick-emoji{font-size:24px}.quick-name{font-size:13px;font-weight:500}.plan-suggest{background:#00ff0008;border-color:#00ff0040;align-items:center;gap:12px;display:flex}.plan-suggest-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.plan-suggest-label{color:var(--primary);align-items:center;gap:4px;font-size:11px;font-weight:600;display:flex}.plan-suggest-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:700;overflow:hidden}.plan-suggest-macros{color:var(--text-secondary);font-size:11px}.plan-suggest-btn{background:var(--primary);color:#080808;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:10px;flex-shrink:0;align-items:center;gap:4px;padding:10px 16px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:700;display:flex}.plan-suggest-btn:active{transform:scale(.95)}.plan-suggest--done{border-color:var(--primary);justify-content:center}.plan-suggest-done-text{color:var(--primary);align-items:center;gap:6px;font-size:14px;font-weight:600;display:flex}.quick-cal{color:var(--text-secondary);font-size:11px}.quick-item--saved{border-color:var(--primary);background:#00ff000f}.quick-item--saved .quick-cal{color:var(--primary);font-weight:600}.quick-empty{color:var(--text-muted);text-align:center;padding:12px 0;font-size:13px;line-height:1.5}.recent-items{flex-direction:column;gap:4px;display:flex}.recent-item{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text);text-align:left;-webkit-tap-highlight-color:transparent;align-items:center;gap:10px;padding:10px 12px;transition:border-color .2s;display:flex}.recent-item:hover,.recent-item:active{border-color:var(--primary)}.recent-item--saved{border-color:var(--primary);background:#00ff000f}.recent-emoji{flex-shrink:0;font-size:18px}.recent-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.recent-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.recent-macros{color:var(--text-secondary);font-size:11px}.recent-action{color:var(--primary);flex-shrink:0}.wizard-overlay{z-index:9500;background:var(--bg);-webkit-overflow-scrolling:touch;position:fixed;inset:0;overflow-y:auto}.wizard{flex-direction:column;max-width:480px;min-height:100vh;margin:0 auto;padding:0 16px 40px;display:flex}.wizard-header{background:var(--bg);z-index:10;align-items:center;gap:12px;padding:16px 0;display:flex;position:sticky;top:0}.wizard-progress{flex:1;gap:4px;display:flex}.wizard-progress-step{background:var(--border);border-radius:2px;flex:1;height:4px;transition:background .3s}.wizard-progress-step.active{background:#0f0}.wizard-close{border:1px solid var(--border);background:var(--bg-elevated);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.wizard-step{flex-direction:column;flex:1;gap:20px;padding-top:8px;display:flex}.wizard-title{color:var(--text);font-size:22px;font-weight:700}.wizard-subtitle{color:var(--text-secondary);margin-top:-12px;font-size:14px}.wizard-section{flex-direction:column;gap:10px;display:flex}.wizard-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.wizard-chips{flex-wrap:wrap;gap:8px;display:flex}.wiz-chip{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:12px;align-items:center;gap:6px;padding:10px 16px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;transition:all .2s;display:flex}.wiz-chip.active{color:#0f0;background:#00ff001f;border-color:#0f0;font-weight:600}.wiz-chip--toggle.active{border-color:var(--danger);color:var(--danger);background:#ff44441f}.wiz-chip-sub{color:var(--text-muted);font-size:11px}.wiz-chip.active .wiz-chip-sub{color:#0f09}.exclusion-input-row{gap:8px;display:flex}.exclusion-input{background:var(--bg-card);border:1px solid var(--border);color:var(--text);border-radius:10px;outline:none;flex:1;padding:10px 14px;font-family:DM Sans,sans-serif;font-size:14px;transition:border-color .2s}.exclusion-input:focus{border-color:#0f0}.exclusion-input::placeholder{color:var(--text-muted)}.exclusion-add-btn{color:#0f0;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#00ff001f;border:1px solid #0f0;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;transition:opacity .2s;display:flex}.exclusion-add-btn:disabled{opacity:.3;cursor:not-allowed}.exclusion-chips{flex-wrap:wrap;gap:6px;display:flex}.exclusion-chip{color:var(--danger);background:#ff44441a;border:1px solid #ff44444d;border-radius:8px;align-items:center;gap:4px;padding:6px 10px;font-size:13px;font-weight:500;display:flex}.exclusion-chip-x{color:var(--danger);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;padding:0 0 0 2px;font-size:16px;line-height:1}.wizard-nav{gap:10px;margin-top:auto;padding-top:16px;display:flex}.wizard-next{color:#080808;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#0f0;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:8px;padding:14px;font-family:DM Sans,sans-serif;font-size:16px;font-weight:700;transition:opacity .2s;display:flex}.wizard-next:disabled{opacity:.4;cursor:not-allowed}.wizard-next:active{transform:scale(.98)}.wizard-next--save{background:#0f0}.wizard-back{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:12px;flex-shrink:0;align-items:center;gap:4px;padding:14px 18px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;display:flex}.swipe-filters{flex-wrap:wrap;gap:6px;display:flex}.swipe-filter-chip{color:#0f0;white-space:nowrap;background:#00ff0014;border:1px solid #00ff0040;border-radius:8px;padding:5px 10px;font-size:12px;font-weight:500}.swipe-error{color:var(--warning);text-align:center;background:#ffaa0014;border:1px solid #ffaa0040;border-radius:10px;padding:10px 14px;font-size:13px;font-weight:500}.swipe-meal-label{text-align:center;color:#0f0;font-size:15px;font-weight:700}.swipe-intro-card{background:var(--bg-card);text-align:center;border:1px solid #00ff0040;border-radius:20px;flex-direction:column;justify-content:center;align-items:center;gap:16px;width:100%;max-width:340px;padding:40px 24px;display:flex}.swipe-intro-emoji{font-size:48px}.swipe-intro-text{color:var(--text);font-size:18px;font-weight:700;line-height:1.4}.swipe-intro-btn{color:#080808;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#0f0;border:none;border-radius:12px;align-items:center;gap:6px;padding:12px 24px;font-family:DM Sans,sans-serif;font-size:15px;font-weight:700;display:flex}.swipe-intro-btn:active{transform:scale(.97)}.wizard-step--swipe{min-height:calc(100vh - 100px)}.swipe-area{flex:1;justify-content:center;align-items:center;min-height:380px;display:flex;position:relative}.swipe-loading{color:var(--text-secondary);flex-direction:column;align-items:center;gap:12px;padding:60px 0;font-size:15px;display:flex}.swipe-card{background:var(--bg-card);border:1px solid var(--border);cursor:grab;touch-action:pan-y;border-radius:20px;width:100%;max-width:340px;position:absolute;overflow:hidden;box-shadow:0 8px 32px #0006}.swipe-card:active{cursor:grabbing}.swipe-card-img{object-fit:cover;background:var(--bg-elevated);width:100%;height:220px}.swipe-card-img--placeholder{justify-content:center;align-items:center;font-size:64px;display:flex}.swipe-card-info{flex-direction:column;gap:8px;padding:16px;display:flex}.swipe-card-name{color:var(--text);font-size:18px;font-weight:700;line-height:1.3}.swipe-card-macros{flex-wrap:wrap;gap:10px;display:flex}.swipe-macro{color:var(--text-secondary);align-items:center;gap:3px;font-size:13px;font-weight:600;display:flex}.swipe-macro--cal{color:#0f0}.swipe-card-desc{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:13px;line-height:1.4;display:-webkit-box;overflow:hidden}.swipe-overlay{z-index:5;pointer-events:none;border-radius:20px;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.swipe-overlay span{letter-spacing:4px;border:4px solid;border-radius:12px;padding:8px 20px;font-size:32px;font-weight:900;transform:rotate(-15deg)}.swipe-overlay--like{background:#00ff0014}.swipe-overlay--like span{color:#0f0;border-color:#0f0}.swipe-overlay--nope{background:#ff444414}.swipe-overlay--nope span{color:#f44;border-color:#f44;transform:rotate(15deg)}.swipe-buttons{justify-content:center;gap:32px;padding:8px 0;display:flex}.swipe-btn{cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:2px solid;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;transition:all .2s;display:flex}.swipe-btn:active{transform:scale(.9)}.swipe-btn--nope{color:#f44;border-color:#f44}.swipe-btn--nope:hover{background:#ff44441a}.swipe-btn--like{color:#0f0;border-color:#0f0}.swipe-btn--like:hover{background:#00ff001a}.swipe-counter{text-align:center;color:var(--text-muted);font-size:13px;font-weight:500}.swipe-liked-count{color:#0f0}.swipe-done{flex-direction:column;align-items:center;gap:12px;padding:40px 0;display:flex}.swipe-done-emoji{font-size:48px}.swipe-done p{color:var(--text);font-size:18px;font-weight:700}.plan-reasoning{align-items:flex-start;gap:10px;display:flex}.plan-reasoning-avatar{object-fit:cover;object-position:center top;border:2px solid #0f0;border-radius:50%;flex-shrink:0;width:40px;height:40px}.plan-reasoning-bubble{background:var(--bg-card);color:var(--text);border:1px solid #00ff0040;border-radius:14px;flex:1;padding:12px 14px;font-size:14px;font-weight:500;line-height:1.45}.plan-tabs{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:3px;display:flex}.plan-tab{color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:9px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;transition:all .2s;display:flex}.plan-tab.active{color:#0f0;background:#00ff001f;font-weight:600}.plan-error{text-align:center;color:var(--danger);flex-direction:column;align-items:center;gap:16px;padding:40px 0;font-size:14px;display:flex}.plan-day-tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:6px;padding-bottom:4px;display:flex;overflow-x:auto}.plan-day-tabs::-webkit-scrollbar{display:none}.plan-day-tab{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:10px;flex-direction:column;flex-shrink:0;align-items:center;gap:1px;padding:8px 14px;transition:all .2s;display:flex}.plan-day-tab.active{color:#0f0;background:#00ff001f;border-color:#0f0}.plan-day-tab-date{font-size:10px;font-weight:500}.plan-day-tab-num{font-size:12px;font-weight:700}.plan-week-tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:6px;display:flex;overflow-x:auto}.plan-week-tabs::-webkit-scrollbar{display:none}.plan-week-tab{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:10px;flex-shrink:0;padding:8px 16px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;transition:all .2s}.plan-week-tab.active{color:#080808;background:#0f0;border-color:#0f0}.plan-day-nav{justify-content:space-between;align-items:center;gap:12px;display:flex}.plan-day-arrow{border:1px solid var(--border);background:var(--bg-card);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:flex}.plan-day-arrow:hover:not(:disabled){color:#0f0;border-color:#0f0}.plan-day-arrow:disabled{opacity:.25;cursor:not-allowed}.plan-day-nav-label{flex-direction:column;align-items:center;gap:1px;display:flex}.plan-day-nav-date{color:var(--text);font-size:16px;font-weight:700}.plan-day-nav-tag{color:#0f0;font-size:12px;font-weight:600}.plan-day{touch-action:pan-y;flex-direction:column;gap:10px;display:flex}.plan-macro-bars{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:8px;padding:14px;display:flex}.plan-macro-bar{flex-direction:column;gap:4px;display:flex}.plan-macro-bar-head{justify-content:space-between;align-items:baseline;display:flex}.plan-macro-bar-label{color:var(--text-secondary);font-size:12px;font-weight:600}.plan-macro-bar-val{color:var(--text);font-size:13px;font-weight:700}.plan-macro-bar-goal{color:var(--text-muted);font-size:12px;font-weight:400}.plan-macro-bar-track{background:var(--bg-elevated);border-radius:3px;height:6px;overflow:hidden}.plan-macro-bar-fill{border-radius:3px;height:100%;transition:width .4s}.plan-macro-bar-fill--green{background:#0f0}.plan-macro-bar-fill--orange{background:#fa0}.plan-macro-bar-fill--red{background:#f44}.plan-meal-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;transition:border-color .2s;overflow:hidden}.plan-meal-card.expanded{border-color:#00ff004d}.plan-meal-header{cursor:pointer;-webkit-tap-highlight-color:transparent;align-items:center;gap:10px;padding:14px;display:flex}.plan-meal-type{color:var(--text-muted);text-transform:uppercase;flex-shrink:0;min-width:75px;font-size:11px;font-weight:600}.plan-meal-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.plan-meal-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.plan-meal-macros{color:var(--text-secondary);font-size:12px}.plan-meal-chevron{color:var(--text-muted);flex-shrink:0;transition:transform .3s}.plan-meal-chevron.open{transform:rotate(180deg)}.plan-meal-detail{border-top:1px solid var(--border);flex-direction:column;gap:10px;padding:0 14px 14px;display:flex;overflow:hidden}.plan-meal-desc{color:var(--text-secondary);padding-top:10px;font-size:13px;line-height:1.5}.plan-meal-ingredients{flex-wrap:wrap;align-items:center;gap:6px;padding-top:4px;display:flex}.plan-meal-ing-label{color:var(--text-secondary);font-size:12px;font-weight:600}.plan-meal-ing{background:var(--bg-elevated);color:var(--text-secondary);border-radius:6px;padding:4px 8px;font-size:12px}.plan-swap-btn{border:1px dashed var(--border);color:var(--text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:10px;font-family:DM Sans,sans-serif;font-size:13px;transition:all .2s;display:flex}.plan-swap-btn:hover{color:#0f0;border-color:#0f0}.plan-swap-btn:disabled{opacity:.5}.shopping-list{flex-direction:column;gap:16px;display:flex}.shopping-category{flex-direction:column;gap:4px;display:flex}.shopping-cat-title{color:#0f0;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);padding-bottom:4px;font-size:13px;font-weight:700}.shopping-item{cursor:pointer;-webkit-tap-highlight-color:transparent;border-bottom:1px solid #22222280;align-items:flex-start;gap:10px;padding:10px 0;display:flex}.shopping-item:last-child{border-bottom:none}.shopping-item input[type=checkbox]{accent-color:#0f0;flex-shrink:0;width:20px;height:20px;margin-top:1px}.shopping-item.checked .shopping-item-name{color:var(--text-muted);text-decoration:line-through}.shopping-item-info{flex-direction:column;flex:1;gap:2px;display:flex}.shopping-item-name{color:var(--text);font-size:14px;font-weight:500}.shopping-item-name b{font-weight:700}.shopping-pantry-badge{color:var(--info);background:#00aaff1f;border-radius:4px;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:600;display:inline-block}.shopping-item.pantry .shopping-item-name{color:var(--text-secondary)}.shopping-item-used{color:var(--text-muted);font-size:11px}.shopping-copy-btn{background:var(--bg-card);border:1px solid var(--border);width:100%;color:var(--text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:12px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:600;transition:all .2s;display:flex}.shopping-copy-btn:hover{color:#0f0;border-color:#0f0}.shopping-empty{text-align:center;color:var(--text-muted);padding:20px 0;font-size:14px}.plan-generating{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:60px 0;display:flex}.plan-bruno{object-fit:cover;object-position:center top;border:3px solid #0f0;border-radius:50%;width:80px;height:80px;animation:1.5s ease-in-out infinite bruno-pulse}@keyframes bruno-pulse{0%,to{transform:scale(1);box-shadow:0 0 #00ff004d}50%{transform:scale(1.05);box-shadow:0 0 20px 4px #0f03}}.plan-generating p{color:var(--text);font-size:16px;font-weight:600}.recipes{flex-direction:column;gap:16px;display:flex}.recipes header{margin-bottom:4px}.recipe-search{position:relative}.recipe-search-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.recipe-search-input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);padding:12px 14px 12px 42px;font-family:inherit;font-size:15px;transition:border-color .2s}.recipe-search-input::placeholder{color:var(--text-muted)}.recipe-search-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px #00ff001a}.meal-plan-btn{border:1.5px dashed var(--primary);border-radius:var(--radius);width:100%;color:var(--primary);cursor:pointer;-webkit-tap-highlight-color:transparent;background:#00ff0014;justify-content:center;align-items:center;gap:8px;padding:14px;font-family:DM Sans,sans-serif;font-size:15px;font-weight:600;transition:all .2s;display:flex}.meal-plan-btn:hover{background:#00ff0026}.meal-plan-btn:active{transform:scale(.98)}.remaining-macros{align-items:center;gap:10px;padding:12px 16px;display:flex}.remaining-label{color:var(--text-secondary);white-space:nowrap;font-size:13px;font-weight:600}.remaining-values{flex-wrap:wrap;flex:1;justify-content:flex-end;gap:10px;display:flex}.remaining-val{color:var(--text-secondary);white-space:nowrap;font-size:13px;font-weight:600}.remaining-val--primary{color:var(--primary)}.macro-fit{border-radius:8px;align-items:center;gap:8px;padding:8px 12px;font-size:13px;font-weight:500;display:flex}.macro-fit--green{color:var(--primary);background:#00ff0014;border:1px solid #00ff0040}.macro-fit--yellow{color:var(--warning);background:#ffaa0014;border:1px solid #ffaa0040}.filter-chips{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.filter-chips::-webkit-scrollbar{display:none}.chip{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:20px;flex-shrink:0;align-items:center;gap:4px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.chip.active{background:var(--primary);color:#080808;border-color:var(--primary);font-weight:600}.chip:hover:not(.active){border-color:var(--primary);color:var(--primary)}.recipe-grid{flex-direction:column;gap:12px;display:flex}.recipe-section-title{color:var(--text-secondary);align-items:center;gap:6px;margin-top:4px;font-size:14px;font-weight:700;display:flex}.user-recipes-section{flex-direction:column;gap:10px;display:flex}.recipe-card{cursor:pointer;flex-direction:column;gap:10px;transition:border-color .2s,box-shadow .2s;display:flex}.recipe-card:hover{border-color:#00ff004d;box-shadow:0 0 16px #00ff000d}.recipe-card--expanded{border-color:var(--primary);box-shadow:0 0 20px #00ff0014}.recipe-header{align-items:center;gap:14px;display:flex}.recipe-img{object-fit:cover;background:var(--bg-elevated);border-radius:14px;flex-shrink:0;width:56px;height:56px}.recipe-emoji{background:var(--bg-elevated);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:30px;display:flex}.recipe-meta{flex:1;min-width:0}.recipe-name{color:var(--text);margin-bottom:4px;font-size:15px;font-weight:600;line-height:1.3}.recipe-stats{color:var(--text-secondary);gap:12px;font-size:12px;display:flex}.recipe-stats span{align-items:center;gap:4px;display:flex}.recipe-chevron{color:var(--text-muted);flex-shrink:0;transition:transform .3s}.recipe-chevron--open{transform:rotate(180deg)}.recipe-ingredients-preview{flex-wrap:wrap;gap:6px;display:flex}.ing-chip{background:var(--bg-elevated);color:var(--text-secondary);white-space:nowrap;border-radius:6px;padding:3px 8px;font-size:11px}.ing-chip--more{color:var(--primary);background:var(--primary-dim)}.recipe-tags{flex-wrap:wrap;gap:6px;display:flex}.recipe-tag{background:var(--primary-dim);color:var(--primary);border-radius:6px;padding:3px 8px;font-size:11px;font-weight:500}.recipe-detail{border-top:1px solid var(--border);flex-direction:column;gap:14px;padding-top:14px;display:flex;overflow:hidden}.detail-macros{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.detail-macro{background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border);flex-direction:column;align-items:center;gap:2px;padding:10px 4px;display:flex}.detail-macro-val{color:var(--primary);font-size:16px;font-weight:700}.detail-macro-lbl{color:var(--text-secondary);font-size:11px}.detail-info-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.detail-time{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;display:flex}.detail-servings{color:var(--text);align-items:center;gap:6px;font-size:13px;display:flex}.serving-btn{background:var(--bg-elevated);border:1px solid var(--border);width:28px;height:28px;color:var(--text);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.serving-btn:hover{border-color:var(--primary);color:var(--primary)}.serving-count{text-align:center;min-width:20px;color:var(--primary);font-size:16px;font-weight:700}.serving-label{color:var(--text-secondary);font-size:12px}.detail-section{flex-direction:column;gap:8px;display:flex}.detail-section h4{color:var(--text-secondary);font-size:13px;font-weight:600}.detail-ingredients{flex-direction:column;gap:4px;list-style:none;display:flex}.detail-ingredients li{color:var(--text);border-bottom:1px solid var(--border);gap:8px;padding:6px 0;font-size:13px;display:flex}.detail-ingredients li:last-child{border-bottom:none}.ing-amount{min-width:80px;color:var(--primary);flex-shrink:0;font-size:12px;font-weight:600}.ing-name{color:var(--text)}.detail-directions{flex-direction:column;gap:10px;list-style:none;display:flex}.detail-directions li{gap:12px;font-size:13px;line-height:1.5;display:flex}.dir-num{background:var(--primary);color:#000;border-radius:50%;justify-content:center;align-items:center;width:24px;min-width:24px;height:24px;margin-top:1px;font-size:12px;font-weight:700;display:flex}.dir-text{color:var(--text-secondary)}.log-recipe-btn{background:var(--primary);color:#000;border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px;font-family:inherit;font-size:14px;font-weight:700;transition:all .2s;display:flex;box-shadow:0 0 16px #0f03}.log-recipe-btn:hover{box-shadow:0 0 24px #00ff0059}.log-recipe-btn--done{background:#22c55e;box-shadow:0 0 16px #22c55e4d}.detail-loading{color:var(--text-secondary);border-top:1px solid var(--border);justify-content:center;align-items:center;gap:8px;margin-top:4px;padding:16px 0;font-size:13px;display:flex}.detail-error{color:#f44;border-top:1px solid var(--border);justify-content:center;align-items:center;gap:8px;margin-top:4px;padding:16px 0;font-size:13px;display:flex}.recipes-error{color:#f44;border-radius:var(--radius);background:#ff44440d;border:1px solid #ff444426;justify-content:center;align-items:center;gap:8px;padding:20px;font-size:13px;display:flex}.no-recipes-hint{color:var(--text-muted);text-align:center;padding:20px 0;font-size:13px}.skeleton-card{cursor:default;flex-direction:row;align-items:center;gap:14px;display:flex}.skeleton-card:hover{border-color:var(--border)}.skeleton-img{background:var(--bg-elevated);border-radius:14px;flex-shrink:0;width:56px;height:56px}.skeleton-body{flex-direction:column;flex:1;gap:8px;display:flex}.skeleton-line{background:var(--bg-elevated);border-radius:6px;height:12px}.skeleton-line--title{width:70%;height:14px}.skeleton-line--short{width:40%}.skeleton-tags{gap:6px;display:flex}.skeleton-line--tag{border-radius:6px;width:50px;height:20px}.shimmer{background:linear-gradient(90deg, var(--bg-elevated) 25%, #ffffff0d 50%, var(--bg-elevated) 75%);background-size:200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.spin{animation:1s linear infinite spin}.load-more-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text-secondary);cursor:pointer;justify-content:center;align-items:center;gap:8px;padding:14px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s;display:flex}.load-more-btn:hover{border-color:var(--primary);color:var(--primary)}.load-more-btn:disabled{opacity:.6;cursor:not-allowed}.coach{flex-direction:column;gap:16px;display:flex}.coach header{margin-bottom:4px}.stats-row{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.stat-card{flex-direction:column;align-items:center;gap:4px;padding:14px 8px;display:flex}.stat-icon{color:var(--text-secondary)}.stat-icon.green{color:var(--primary)}.stat-icon.red{color:var(--danger)}.stat-number{color:var(--text);font-size:22px;font-weight:700}.stat-desc{color:var(--text-secondary);font-size:11px;font-weight:500}.search-bar{position:relative}.search-icon{color:var(--text-muted);position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);outline:none;padding:12px 14px 12px 42px;font-size:14px;transition:border-color .2s}.search-input:focus{border-color:var(--primary)}.search-input::placeholder{color:var(--text-muted)}.active-badge{color:var(--primary);align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.member-list{flex-direction:column;gap:10px;display:flex}.member-card{cursor:pointer;transition:border-color .2s}.member-card:hover{border-color:var(--text-muted)}.member-row{align-items:center;gap:12px;display:flex}.member-avatar{background:var(--bg-elevated);width:42px;height:42px;color:var(--text);border:2px solid;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:600;display:flex}.member-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.member-name{color:var(--text);font-size:14px;font-weight:600}.member-plan{color:var(--text-secondary);font-size:12px}.member-compliance{flex-shrink:0}.compliance-ring{border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;display:flex;position:relative}.compliance-ring span{background:var(--bg-card);width:34px;height:34px;color:var(--text);border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.expand-icon{color:var(--text-muted);flex-shrink:0;transition:transform .3s}.expand-icon.expanded{transform:rotate(90deg)}.member-details{border-top:1px solid var(--border);margin-top:14px;padding-top:14px;overflow:hidden}.detail-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:12px;display:grid}.detail-item{flex-direction:column;gap:2px;display:flex}.detail-label{color:var(--text-secondary);font-size:11px;font-weight:500}.detail-value{color:var(--text);font-size:14px;font-weight:600}.compliance-bar-wrapper{margin-top:4px}.compliance-bar-track{background:var(--bg-elevated);border-radius:3px;height:6px;overflow:hidden}.compliance-bar-fill{border-radius:3px;height:100%}.profile{flex-direction:column;gap:16px;display:flex}.profile-header-card{flex-direction:column;gap:20px;display:flex}.avatar-section{align-items:center;gap:16px;display:flex}.avatar-ring{flex-shrink:0;width:80px;height:80px;position:relative}.avatar-progress{width:100%;height:100%;position:absolute;inset:0}.avatar-placeholder{background:var(--bg-elevated);color:var(--text-muted);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:color .2s;display:flex;position:absolute;inset:6px}.avatar-placeholder:hover{color:var(--primary)}.avatar-level-badge{background:var(--primary);color:#080808;border:2px solid var(--bg-card);border-radius:10px;padding:2px 6px;font-size:10px;font-weight:700;position:absolute;bottom:-2px;right:-2px}.avatar-info{flex-direction:column;gap:2px;display:flex}.avatar-name{color:var(--text);font-size:20px;font-weight:700}.avatar-title{color:var(--primary);font-size:13px;font-weight:500}.gamification-row{border-top:1px solid var(--border);border-bottom:1px solid var(--border);justify-content:space-around;padding:12px 0;display:flex}.gami-stat{flex-direction:column;align-items:center;gap:2px;display:flex}.gami-icon{margin-bottom:2px}.gami-icon.streak{color:#ff6b35}.gami-icon.xp{color:var(--primary)}.gami-icon.trophy{color:#fa0}.gami-value{color:var(--text);font-size:18px;font-weight:700}.gami-label{color:var(--text-secondary);font-size:11px}.xp-bar-section{flex-direction:column;gap:6px;display:flex}.xp-bar-header{justify-content:space-between;display:flex}.xp-bar-label{color:var(--text-secondary);font-size:11px;font-weight:500}.xp-bar-track{background:var(--bg-elevated);border-radius:4px;width:100%;height:8px;overflow:hidden}.xp-bar-fill{background:var(--primary);height:100%;box-shadow:0 0 10px var(--primary-glow);border-radius:4px}.badge-grid{grid-template-columns:repeat(3,1fr);gap:8px;margin-top:4px;display:grid}.badge-item{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);opacity:.35;filter:grayscale();flex-direction:column;align-items:center;gap:4px;padding:14px 8px;transition:all .3s;display:flex;position:relative}.badge-item--unlocked{opacity:1;filter:none;border-color:#00ff0040}.badge-emoji{font-size:28px}.badge-name{color:var(--text-secondary);text-align:center;font-size:11px;font-weight:600;line-height:1.3}.badge-item--unlocked .badge-name{color:var(--text)}.badge-locked{font-size:10px;position:absolute;top:6px;right:6px}.section-title{color:var(--text);margin-bottom:2px;font-size:16px;font-weight:700}.profile-form{flex-direction:column;gap:18px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.form-input{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);outline:none;padding:12px 14px;font-size:15px;transition:border-color .2s}.form-input:focus{border-color:var(--primary)}.form-input::placeholder{color:var(--text-muted)}.form-row{grid-template-columns:1fr 1fr 1fr;gap:10px;display:grid}.toggle-group{gap:8px;display:flex}.goal-group{grid-template-columns:repeat(3,1fr);display:grid}.toggle-btn{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;flex:1;padding:10px 14px;font-size:14px;font-weight:500;transition:all .2s}.toggle-btn.active{background:var(--primary-dim);border-color:var(--primary);color:var(--primary)}.activity-list{flex-direction:column;gap:6px;display:flex}.activity-item{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;text-align:left;flex-direction:column;gap:2px;padding:10px 14px;transition:all .2s;display:flex}.activity-item.active{background:var(--primary-dim);border-color:var(--primary)}.activity-label{color:var(--text);font-size:14px;font-weight:600}.activity-item.active .activity-label{color:var(--primary)}.activity-desc{color:var(--text-muted);font-size:12px}.tdee-card{text-align:center;flex-direction:column;align-items:center;gap:8px;display:flex}.tdee-header{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:6px;font-size:13px;font-weight:600;display:flex}.tdee-value{color:var(--primary);text-shadow:0 0 20px var(--primary-glow);font-size:36px;font-weight:700}.tdee-macros{gap:24px;margin-top:4px;display:flex}.tdee-macro{flex-direction:column;align-items:center;gap:2px;display:flex}.tdee-macro-val{color:var(--text);font-size:16px;font-weight:700}.tdee-macro-label{color:var(--text-secondary);font-size:11px}.tdee-formula{color:var(--text-muted);margin-top:4px;font-size:11px}.coach-hint{border-radius:var(--radius-sm);color:var(--info);background:#00aaff14;border:1px solid #0af3;justify-content:center;align-items:center;gap:6px;padding:10px 14px;font-size:12px;display:flex}.save-profile-btn{background:var(--primary);color:#080808;border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px;font-size:15px;font-weight:600;transition:all .2s;display:flex}.save-profile-btn:active{transform:scale(.98)}.save-profile-btn.saved{background:var(--bg-elevated);color:var(--primary);border:1px solid var(--primary)}.auth-page{background:var(--bg);justify-content:center;align-items:center;min-height:100dvh;padding:24px 20px;display:flex}.auth-container{width:100%;max-width:400px}.auth-logo{text-align:center;margin-bottom:40px}.auth-logo-img{object-fit:contain;height:48px}.auth-tabs{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:24px;padding:4px;display:flex}.auth-tab{border-radius:calc(var(--radius) - 4px);color:var(--text-secondary);cursor:pointer;background:0 0;border:none;flex:1;padding:10px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s}.auth-tab.active{background:var(--primary);color:#000}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-field{flex-direction:column;gap:6px;display:flex}.auth-field label{color:var(--text-secondary);font-size:13px;font-weight:600}.auth-field input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);outline:none;padding:14px 16px;font-family:inherit;font-size:15px;transition:border-color .2s}.auth-field input:focus{border-color:var(--primary)}.auth-field input::placeholder{color:var(--text-muted)}.auth-error{color:#f44;text-align:center;border-radius:var(--radius-sm);background:#ff44441a;padding:10px;font-size:13px}.auth-success{color:var(--primary);text-align:center;background:var(--primary-dim);border-radius:var(--radius-sm);padding:10px;font-size:13px}.auth-btn{background:var(--primary);color:#000;border-radius:var(--radius);cursor:pointer;border:none;width:100%;margin-top:8px;padding:16px;font-family:inherit;font-size:16px;font-weight:700;transition:all .2s;box-shadow:0 0 24px #00ff004d}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.auth-btn:hover:not(:disabled){box-shadow:0 0 32px #00ff0073}.bruno{z-index:8000;pointer-events:none;flex-direction:column;align-items:flex-end;gap:10px;display:flex;position:fixed;bottom:80px;right:16px}.bruno-avatar-wrap{pointer-events:auto;position:relative}.bruno-close{z-index:2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:14px;line-height:1;transition:background .2s;display:flex;position:absolute;top:-4px;right:-4px}.bruno-close:hover,.bruno-close:active{background:#ffffff4d}.bruno-avatar{cursor:pointer;-webkit-tap-highlight-color:transparent;background:#080808;border:3px solid #0f0;border-radius:50%;width:80px;height:80px;padding:0;animation:.6s cubic-bezier(.34,1.56,.64,1) both bruno-entrance;position:relative;overflow:hidden;box-shadow:0 4px 24px #00ff0040,0 2px 12px #00000080}.bruno-avatar:active{transform:scale(.92)}.bruno-img{object-fit:cover;object-position:center top;border-radius:50%;width:100%;height:100%}.bruno-bubble{pointer-events:auto;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#1a1a1a;border:1.5px solid #0f0;border-radius:16px;max-width:260px;padding:14px 16px;animation:.35s cubic-bezier(.34,1.56,.64,1) both bruno-bubble-in;position:relative;box-shadow:0 4px 24px #00ff001f,0 4px 12px #00000080}.bruno-bubble-text{color:#fff;font-family:DM Sans,sans-serif;font-size:15px;font-weight:600;line-height:1.45}.bruno-bubble-arrow{background:#1a1a1a;border-bottom:1.5px solid #0f0;border-right:1.5px solid #0f0;width:14px;height:14px;position:absolute;bottom:-7px;right:28px;transform:rotate(45deg)}@keyframes bruno-entrance{0%{opacity:0;transform:translateY(60px)scale(.3)}60%{opacity:1;transform:translateY(-8px)scale(1.08)}80%{transform:translateY(3px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes bruno-bubble-in{0%{opacity:0;transform:translateY(12px)scale(.9)}to{opacity:1;transform:translateY(0)scale(1)}}.badge-popup-overlay{z-index:9800;background:#000000b3;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.badge-popup{background:var(--bg-card);text-align:center;border:2px solid #0f0;border-radius:24px;flex-direction:column;align-items:center;gap:8px;width:100%;max-width:300px;padding:32px 24px 24px;display:flex;position:relative;overflow:hidden;box-shadow:0 0 40px #0f03}.badge-popup-emoji{font-size:56px;line-height:1}.badge-popup-title{color:#0f0;text-transform:uppercase;letter-spacing:1px;font-size:13px;font-weight:600}.badge-popup-name{color:var(--text);font-size:22px;font-weight:800}.badge-popup-desc{color:var(--text-secondary);margin-bottom:8px;font-size:14px}.badge-popup-btn{color:#080808;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#0f0;border:none;border-radius:12px;width:100%;padding:12px;font-family:DM Sans,sans-serif;font-size:15px;font-weight:700}.badge-popup-btn:active{transform:scale(.97)}.badge-confetti{pointer-events:none;position:absolute;inset:0;overflow:hidden}.badge-confetti-dot{border-radius:50%;width:6px;height:6px;animation:1.5s ease-out forwards confetti-fall;position:absolute;top:-8px}@keyframes confetti-fall{0%{opacity:1;transform:translateY(0)rotate(0)scale(1)}to{opacity:0;transform:translateY(300px)rotate(720deg)scale(.3)}}.app-shell{flex-direction:column;width:100%;max-width:480px;min-height:100dvh;margin:0 auto;display:flex;position:relative}.app-content{flex:1;padding:16px 16px 100px;overflow-y:auto}
