*{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)}.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;min-width:140px;padding:6px 16px;font-size:16px;font-weight:600;transition:all .2s}.date-nav-label:hover{background:var(--bg-card)}.date-nav-label--today{color:var(--primary)}.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}.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}.quick-cal{color:var(--text-secondary);font-size:11px}.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}.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}.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}.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}
