*{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}.page-loading{color:#0f0;justify-content:center;align-items:center;height:50vh;font-size:16px;font-weight:500;display:flex}.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:calc(100% - 32px);max-width:450px;padding:10px 8px;padding-bottom:max(10px, env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(12px);z-index:100;background:#ffffff08;border:.5px solid #ffffff1a;border-radius:24px;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:12px;left:50%;transform:translate(-50%);box-shadow:0 4px 24px #0006}.nav-item{color:#ffffffb3;border-radius:16px;flex-direction:column;align-items:center;gap:4px;padding:8px 14px;font-size:11px;font-weight:500;text-decoration:none;transition:all .3s;display:flex;position:relative}.nav-item.active{color:var(--primary);background:#00ff0026;border-radius:50px}.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}.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)}.streak-overlay{z-index:200;-webkit-overflow-scrolling:touch;background:#000000eb;position:fixed;inset:0;overflow-y:auto}.streak-content{max-width:400px;padding:20px;padding-top:max(20px, env(safe-area-inset-top));text-align:center;margin:0 auto;padding-bottom:100px;position:relative}.streak-close{top:max(16px, env(safe-area-inset-top));color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;padding:8px;transition:color .2s;position:absolute;right:16px}.streak-close:hover{color:var(--text)}.streak-title{color:var(--text);margin-bottom:20px;font-size:20px;font-weight:700}@keyframes wave{0%,to{transform:rotate(0)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}.streak-bruno{object-fit:cover;object-position:center top;border:3px solid var(--primary);border-radius:50%;width:100px;height:100px;margin:0 auto 16px;animation:2s ease-in-out infinite wave;display:block}@keyframes flamePulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.streak-flame{margin:12px 0;font-size:64px;line-height:1;animation:2s ease-in-out infinite flamePulse}.streak-count{margin:8px 0 4px;font-size:48px;font-weight:700}.streak-tier-label{text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;font-size:14px;font-weight:600}.streak-motivation{color:var(--text-muted);margin-bottom:24px;font-size:16px;line-height:1.4}.skill-tree{flex-direction:column;align-items:center;gap:0;margin:32px 0;display:flex}.tree-node{border-radius:16px;align-items:center;gap:12px;width:100%;max-width:280px;padding:12px 20px;transition:all .3s;display:flex}.tree-node.locked{opacity:.3;filter:grayscale()}.tree-node.reached{opacity:1}.tree-node.current{background:#ffffff0d}.tree-emoji{flex-shrink:0;font-size:28px}.tree-info{text-align:left;flex:1}.tree-label{color:var(--text);font-size:16px;font-weight:500;display:block}.tree-days{color:var(--text-muted);font-size:12px}.tree-check{color:var(--primary);flex-shrink:0;font-size:16px;font-weight:700}.tree-connector{background:#ffffff1a;width:2px;height:24px;margin:0 auto}.tree-connector.reached{background:var(--primary)}.tree-progress{width:100%;max-width:280px;margin:0 auto 8px}.tree-progress-bar{background:#ffffff1a;border-radius:2px;height:4px;overflow:hidden}.tree-progress-fill{border-radius:2px;height:100%;transition:width .5s}.tree-progress-label{color:var(--text-muted);margin-top:4px;font-size:11px;display:block}.streak-stats{border-top:1px solid var(--border);margin-top:32px;padding-top:24px}.streak-stats-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px;font-size:14px;font-weight:600}.streak-stats-grid{grid-template-columns:repeat(4,1fr);gap:4px;display:grid}.streak-stats-item{background:#ffffff0a;border-radius:12px;flex-direction:column;align-items:center;gap:2px;padding:10px 4px;display:flex}.streak-stats-val{color:var(--text);font-size:18px;font-weight:700}.streak-stats-sub{color:var(--text-muted);font-size:13px;font-weight:400}.streak-stats-lbl{color:var(--text-secondary);text-align:center;font-size:10px}.streak-trend{justify-content:center;align-items:center;gap:6px;margin-top:12px;font-size:12px;font-weight:500;display:flex}.streak-trend--up{color:#0f0}.streak-trend--down{color:#f44}.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{cursor:pointer;-webkit-tap-highlight-color:transparent;border:1px solid;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-family:inherit;font-size:13px;font-weight:600;transition:transform .15s;display:flex}.streak-badge:active{transform:scale(.95)}.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,.overview-card{flex-direction:column;align-items:center;display:flex}.overview-top{justify-content:center;align-items:center;gap:28px;width:100%;display:flex}.overview-stat{text-align:center}.overview-stat-value{color:var(--text);font-size:22px;font-weight:700;display:block}.overview-stat-label{color:var(--text-muted);margin-top:4px;font-size:12px;display:block}.overview-ring{flex-shrink:0;width:120px;height:120px}.overview-ring .calorie-ring-wrapper{width:120px;height:120px}.overview-ring .calorie-ring-number{font-size:24px}.overview-ring .calorie-ring-label{font-size:10px}.overview-activity{color:var(--primary);justify-content:center;align-items:center;gap:6px;margin-top:8px;font-size:13px;font-weight:600;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}.overview-macros{gap:12px;width:100%;margin-top:20px;display:flex}.overview-macro-col{flex-direction:column;flex:1;gap:4px;display:flex}.overview-macro-col label{font-size:12px;font-weight:500}.overview-macro-col .track{background:#1f1f1f;border-radius:3px;height:6px;overflow:hidden}.overview-macro-col .fill{border-radius:3px;height:100%;transition:width .3s}.overview-macro-col .value{color:var(--text-muted);font-size:11px}.nutrition-section{flex-direction:column;gap:8px;display:flex}.nutrition-section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:500}.nutrition-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;overflow:hidden}.nutrition-row-wrap{border-bottom:.5px solid #ffffff0d}.nutrition-row-wrap:last-child{border-bottom:none}.nutrition-row{cursor:pointer;-webkit-tap-highlight-color:transparent;align-items:center;padding:14px 16px;display:flex}.nutrition-emoji{background:#ffffff0d;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;margin-right:12px;font-size:20px;display:flex}.nutrition-info{flex:1;min-width:0}.nutrition-name{color:var(--text);font-size:15px;font-weight:500;display:block}.nutrition-kcal{color:var(--text-muted);margin-top:2px;font-size:12px;display:block}.nutrition-chevron{color:var(--text-muted);flex-shrink:0;margin-right:10px;transition:transform .3s}.nutrition-chevron--open{transform:rotate(180deg)}.nutrition-add-btn{background:var(--primary);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:transform .15s;display:flex}.nutrition-add-btn:active{transform:scale(.9)}.nutrition-add-btn svg{color:#000}.nutrition-sub-items{padding:4px 16px 12px 68px;overflow:hidden}.nutrition-logged-item{border-bottom:.5px solid #ffffff08;justify-content:space-between;align-items:center;padding:6px 0;font-size:13px;display:flex}.nutrition-logged-item:last-child{border-bottom:none}.nutrition-logged-name{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.nutrition-logged-meta{flex-shrink:0;align-items:center;gap:8px;display:flex}.nutrition-logged-kcal{color:var(--text-muted);white-space:nowrap;font-size:12px}.nutrition-logged-time{color:var(--text-muted);font-size:11px}.nutrition-sub-items .plan-today-item{margin-top:4px;margin-bottom:4px}.plan-today-label{color:var(--text-muted);letter-spacing:.3px;font-size:10px;font-weight:600}.water-header{align-items:center;gap:8px;margin-bottom:4px;display:flex}.water-header-icon{color:#0af}.water-title{margin-bottom:0!important}.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}.collapsible-card{overflow:hidden}.collapsible-header{width:100%;color:var(--text);cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;gap:8px;padding:0;font-family:inherit;display:flex}.collapsible-title-row{flex-shrink:0;align-items:center;gap:8px;display:flex}.collapsible-title{font-size:14px;margin:0!important}.collapsible-icon{color:var(--primary);align-items:center;display:flex}.collapsible-summary{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;text-align:right;flex:1;padding-right:4px;font-size:12px;overflow:hidden}.collapsible-chevron{color:var(--text-muted);flex-shrink:0;transition:transform .3s}.collapsible-chevron--open{transform:rotate(180deg)}.collapsible-body{padding-top:12px;overflow:hidden}.collapsible-card .health-connect-btn{margin-bottom:4px;margin-left:auto;display:flex}.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}
