@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--primary-hue: 200;--primary-sat: 95%;--primary-50: hsl(var(--primary-hue), var(--primary-sat), 97%);--primary-100: hsl(var(--primary-hue), var(--primary-sat), 90%);--primary-200: hsl(var(--primary-hue), var(--primary-sat), 80%);--primary-300: hsl(var(--primary-hue), var(--primary-sat), 70%);--primary-400: hsl(var(--primary-hue), var(--primary-sat), 60%);--primary-500: hsl(var(--primary-hue), var(--primary-sat), 50%);--primary-600: hsl(var(--primary-hue), var(--primary-sat), 45%);--primary-700: hsl(var(--primary-hue), var(--primary-sat), 35%);--primary-800: hsl(var(--primary-hue), var(--primary-sat), 25%);--primary-900: hsl(var(--primary-hue), var(--primary-sat), 15%);--accent-orange: hsl(25, 95%, 60%);--accent-green: hsl(145, 70%, 50%);--accent-purple: hsl(270, 70%, 60%);--accent-pink: hsl(330, 80%, 65%);--success: hsl(145, 70%, 50%);--warning: hsl(40, 95%, 55%);--error: hsl(0, 85%, 60%);--info: hsl(200, 95%, 55%);--gray-50: hsl(220, 20%, 98%);--gray-100: hsl(220, 15%, 95%);--gray-200: hsl(220, 15%, 90%);--gray-300: hsl(220, 12%, 80%);--gray-400: hsl(220, 10%, 65%);--gray-500: hsl(220, 8%, 50%);--gray-600: hsl(220, 10%, 40%);--gray-700: hsl(220, 12%, 30%);--gray-800: hsl(220, 15%, 20%);--gray-900: hsl(220, 18%, 12%);--bg-primary: var(--gray-50);--bg-secondary: white;--bg-tertiary: var(--gray-100);--text-primary: var(--gray-900);--text-secondary: var(--gray-600);--text-tertiary: var(--gray-500);--border-color: var(--gray-200);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 40px rgba(0, 0, 0, .15);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--gradient-primary: linear-gradient(135deg, var(--primary-500) 0%, var(--primary-700) 100%);--gradient-accent: linear-gradient(135deg, var(--accent-orange) 0%, var(--accent-pink) 100%);--gradient-success: linear-gradient(135deg, var(--success) 0%, hsl(145, 70%, 40%) 100%);--gradient-bg: linear-gradient(180deg, var(--bg-primary) 0%, var(--bg-tertiary) 100%)}[data-theme=dark]{--bg-primary: var(--gray-900);--bg-secondary: var(--gray-800);--bg-tertiary: var(--gray-700);--text-primary: var(--gray-50);--text-secondary: var(--gray-300);--text-tertiary: var(--gray-400);--border-color: var(--gray-700);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 40px rgba(0, 0, 0, .6);--gradient-bg: linear-gradient(180deg, var(--gray-900) 0%, var(--gray-800) 100%)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:var(--font-size-base);line-height:1.6;color:var(--text-primary);background:var(--gradient-bg);min-height:100vh;transition:background var(--transition-base),color var(--transition-base)}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;margin-bottom:var(--space-md);color:var(--text-primary)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}p{margin-bottom:var(--space-md);color:var(--text-secondary)}a{color:var(--primary-500);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-600)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--space-lg)}.glass{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);box-shadow:var(--shadow-lg)}[data-theme=dark] .glass{background:#ffffff0d;border:1px solid rgba(255,255,255,.1)}.card{background:var(--bg-secondary);border-radius:var(--radius-xl);padding:var(--space-xl);box-shadow:var(--shadow-md);transition:transform var(--transition-base),box-shadow var(--transition-base)}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.gradient-text{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.gradient-border{position:relative;border-radius:var(--radius-lg);padding:2px;background:var(--gradient-primary)}.gradient-border:before{content:"";position:absolute;inset:2px;background:var(--bg-secondary);border-radius:calc(var(--radius-lg) - 2px);z-index:-1}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-base);font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:var(--gray-300)}.btn-success{background:var(--gradient-success);color:#fff}.btn-outline{background:transparent;border:2px solid var(--primary-500);color:var(--primary-500)}.btn-outline:hover:not(:disabled){background:var(--primary-500);color:#fff}.btn-sm{padding:var(--space-xs) var(--space-md);font-size:var(--font-size-sm)}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:var(--font-size-lg)}.btn-icon{padding:var(--space-sm);border-radius:var(--radius-full)}.form-group{margin-bottom:var(--space-lg)}.form-label{display:block;margin-bottom:var(--space-sm);font-weight:600;font-size:var(--font-size-sm);color:var(--text-primary)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-md);font-size:var(--font-size-base);font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f61a}.form-textarea{resize:vertical;min-height:100px}.grid{display:grid;gap:var(--space-lg)}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.grid-4{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{to{transform:rotate(360deg)}}.animate-fadeIn{animation:fadeIn var(--transition-base) ease-out}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-spin{animation:spin 1s linear infinite}.progress-bar{width:100%;height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width var(--transition-slow)}.badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-xs);font-weight:600;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.5px}.badge-primary{background:var(--primary-100);color:var(--primary-700)}.badge-success{background:#d4f7e3;color:#178244}.badge-warning{background:#feeecd;color:#956504}.badge-error{background:#fbd0d0;color:#bd0f0f}@media(max-width:768px){html{font-size:14px}.container{padding:0 var(--space-md)}.card{padding:var(--space-lg)}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-tertiary)}::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}[data-theme=dark] ::-webkit-scrollbar-track{background:var(--gray-800)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--gray-600)}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1;padding-top:var(--space-md)}.footer{margin-top:auto;padding:var(--space-xl);text-align:center;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.footer p{margin:0;color:var(--text-tertiary);font-size:var(--font-size-sm)}.coming-soon{max-width:800px;margin:0 auto;padding:var(--space-xl)}.coming-soon-content{text-align:center;padding:var(--space-3xl)}.coming-soon-icon{font-size:5rem;margin-bottom:var(--space-xl);animation:pulse 2s ease-in-out infinite}.coming-soon-content h2{margin-bottom:var(--space-md);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.coming-soon-content p{font-size:var(--font-size-lg);color:var(--text-secondary);margin-bottom:var(--space-2xl)}.coming-soon-features{text-align:left;max-width:500px;margin:0 auto;padding:var(--space-xl);background:var(--bg-tertiary);border-radius:var(--radius-lg)}.coming-soon-features h4{margin-bottom:var(--space-md);color:var(--text-primary)}.coming-soon-features ul{list-style:none;padding:0}.coming-soon-features li{padding:var(--space-sm) 0;color:var(--text-secondary);font-size:var(--font-size-base)}.header{position:sticky;top:0;z-index:1000;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-container{max-width:1400px;margin:0 auto;padding:var(--space-md) var(--space-lg);display:flex;align-items:center;justify-content:space-between;gap:var(--space-xl)}.header-brand{display:flex;flex-direction:column;gap:var(--space-xs)}.logo{display:flex;align-items:center;gap:var(--space-sm)}.logo-icon{font-size:var(--font-size-2xl);animation:pulse 2s ease-in-out infinite}.logo-text{font-size:var(--font-size-2xl);font-weight:800;letter-spacing:-.5px}.tagline{font-size:var(--font-size-xs);color:var(--text-tertiary);font-weight:500;margin-left:calc(var(--font-size-2xl) + var(--space-sm))}.nav-desktop{display:flex;gap:var(--space-sm);flex:1;justify-content:center}.nav-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);background:transparent;border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);position:relative}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary);transform:translateY(-1px)}.nav-item.active{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md)}.nav-icon{font-size:var(--font-size-lg)}.header-actions{display:flex;gap:var(--space-sm);align-items:center}.theme-toggle{background:var(--bg-tertiary);color:var(--text-primary)}.theme-toggle:hover{background:var(--primary-500);color:#fff}.mobile-menu-toggle,.nav-mobile{display:none}@media(max-width:968px){.nav-desktop{display:none}.mobile-menu-toggle{display:flex;background:var(--bg-tertiary);color:var(--text-primary)}.nav-mobile{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-md);background:var(--bg-primary);border-top:1px solid var(--border-color)}.nav-item-mobile{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-secondary);border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%}.nav-item-mobile:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item-mobile.active{background:var(--gradient-primary);color:#fff}.tagline{display:none}.logo-text,.logo-icon{font-size:var(--font-size-xl)}}@media(max-width:480px){.header-container{padding:var(--space-sm) var(--space-md)}.logo-text,.logo-icon{font-size:var(--font-size-lg)}}.dashboard{max-width:1200px;margin:0 auto;padding:var(--space-xl)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl);flex-wrap:wrap;gap:var(--space-md)}.dashboard-header h1{margin-bottom:var(--space-xs)}.dashboard-header p{color:var(--text-secondary);margin:0}.calorie-card{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2xl);margin-bottom:var(--space-xl);padding:var(--space-2xl)}.calorie-ring-container{position:relative;display:flex;justify-content:center;align-items:center}.calorie-ring{width:280px;height:280px}.calorie-progress{transition:stroke-dasharray 1s ease-out}.calorie-center{position:absolute;display:flex;flex-direction:column;align-items:center;gap:var(--space-xs)}.calorie-icon{color:var(--primary-500);margin-bottom:var(--space-sm);animation:pulse 2s ease-in-out infinite}.calorie-numbers{display:flex;align-items:baseline;gap:var(--space-xs)}.calorie-current{font-size:var(--font-size-3xl);font-weight:800;color:var(--text-primary)}.calorie-divider{font-size:var(--font-size-xl);color:var(--text-tertiary)}.calorie-goal{font-size:var(--font-size-xl);font-weight:600;color:var(--text-secondary)}.calorie-label{font-size:var(--font-size-sm);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1px}.calorie-remaining{font-size:var(--font-size-sm);font-weight:600;color:var(--success);margin-top:var(--space-sm)}.calorie-remaining.over{color:var(--error)}.macro-breakdown{display:flex;flex-direction:column;gap:var(--space-lg);justify-content:center}.macro-item{display:flex;flex-direction:column;gap:var(--space-sm)}.macro-header{display:flex;justify-content:space-between;align-items:center}.macro-name{font-weight:600;color:var(--text-primary);font-size:var(--font-size-base)}.macro-value{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-lg);margin-bottom:var(--space-xl)}.stat-card{display:flex;gap:var(--space-lg);align-items:center;padding:var(--space-xl)}.stat-icon{width:60px;height:60px;border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.stat-content{display:flex;flex-direction:column;gap:var(--space-xs);flex:1}.stat-label{font-size:var(--font-size-sm);color:var(--text-tertiary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:var(--font-size-2xl);font-weight:800;color:var(--text-primary)}.stat-subtext{font-size:var(--font-size-sm);color:var(--text-secondary)}.recent-meals{padding:var(--space-xl)}.recent-meals h3{margin-bottom:var(--space-lg)}.meals-list{display:flex;flex-direction:column;gap:var(--space-md)}.meal-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);transition:all var(--transition-fast)}.meal-item:hover{background:var(--bg-primary);transform:translate(4px)}.meal-info{display:flex;flex-direction:column;gap:var(--space-xs)}.meal-name{font-weight:600;color:var(--text-primary)}.meal-time{font-size:var(--font-size-sm);color:var(--text-tertiary)}.meal-macros{display:flex;gap:var(--space-md);align-items:center}.meal-calories{font-weight:700;color:var(--primary-500);font-size:var(--font-size-lg)}.meal-macro{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:600}.empty-state{text-align:center;padding:var(--space-3xl);display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.empty-icon{font-size:4rem;margin-bottom:var(--space-md);opacity:.5}.empty-state h3{margin-bottom:var(--space-sm)}.empty-state p{color:var(--text-secondary);margin-bottom:var(--space-lg)}@media(max-width:968px){.calorie-card{grid-template-columns:1fr;gap:var(--space-xl)}.calorie-ring{width:240px;height:240px}.stats-grid{grid-template-columns:1fr}}@media(max-width:640px){.dashboard{padding:var(--space-md)}.calorie-card{padding:var(--space-lg)}.calorie-ring{width:200px;height:200px}.calorie-current{font-size:var(--font-size-2xl)}.calorie-goal{font-size:var(--font-size-lg)}.meal-macros{flex-direction:column;align-items:flex-end;gap:var(--space-xs)}.dashboard-header{flex-direction:column;align-items:flex-start}}.food-logger{max-width:1200px;margin:0 auto;padding:var(--space-xl)}.logger-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl);flex-wrap:wrap;gap:var(--space-md)}.logger-actions{display:flex;gap:var(--space-sm);flex-wrap:wrap}.today-summary{margin-bottom:var(--space-xl);padding:var(--space-xl)}.today-summary h3{margin-bottom:var(--space-lg)}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--space-lg)}.summary-stat{display:flex;flex-direction:column;gap:var(--space-xs);text-align:center;padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md)}.summary-label{font-size:var(--font-size-sm);color:var(--text-tertiary);font-weight:600;text-transform:uppercase}.summary-value{font-size:var(--font-size-2xl);font-weight:800;color:var(--primary-500)}.manual-entry{margin-bottom:var(--space-xl);padding:var(--space-xl)}.manual-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-lg);margin-bottom:var(--space-lg)}.search-section{margin-bottom:var(--space-xl);padding:var(--space-xl)}.search-bar{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-lg);border:2px solid var(--border-color);transition:border-color var(--transition-fast)}.search-bar:focus-within{border-color:var(--primary-500)}.search-header{display:flex;flex-direction:column;gap:var(--space-md)}.search-loader{animation:spin 1s linear infinite;color:var(--primary-500)}.api-notice{padding:var(--space-sm) var(--space-md);background:var(--warning);color:var(--gray-900);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.api-notice a{color:var(--primary-700);font-weight:700;text-decoration:underline}.search-toggle{padding:var(--space-sm) 0}.toggle-label{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary)}.toggle-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary-500)}.search-bar svg{color:var(--text-tertiary);flex-shrink:0}.search-input{flex:1;border:none;background:transparent;font-size:var(--font-size-base);color:var(--text-primary);outline:none;font-family:var(--font-sans)}.search-input::placeholder{color:var(--text-tertiary)}.category-filter{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg);overflow-x:auto;padding-bottom:var(--space-sm)}.category-btn{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border:2px solid transparent;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.category-btn:hover{background:var(--bg-primary);color:var(--text-primary)}.category-btn.active{background:var(--primary-500);color:#fff;border-color:var(--primary-600)}.search-results{max-height:400px;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-sm)}.food-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background:var(--bg-tertiary);border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.food-item:hover{background:var(--bg-primary);border-color:var(--primary-300);transform:translate(4px)}.food-item.selected{background:var(--primary-50);border-color:var(--primary-500)}[data-theme=dark] .food-item.selected{background:var(--primary-900)}.food-info{flex:1;display:flex;flex-direction:column;gap:var(--space-xs)}.food-name-row{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.food-name{font-weight:700;color:var(--text-primary);font-size:var(--font-size-base)}.food-brand{font-size:var(--font-size-xs);color:var(--text-tertiary);font-style:italic}.food-badge{padding:2px 8px;background:var(--success);color:#fff;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px}.food-nutrition{display:flex;gap:var(--space-md);align-items:center}.food-calories{font-weight:700;color:var(--primary-500);font-size:var(--font-size-lg)}.food-macro{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:600}.no-results{text-align:center;padding:var(--space-2xl);color:var(--text-tertiary)}.selected-food{padding:var(--space-xl);border:2px solid var(--primary-500)}.selected-details h4{margin-bottom:var(--space-xs)}.selected-details p{color:var(--text-tertiary);margin-bottom:var(--space-lg)}.servings-control{margin-bottom:var(--space-lg)}.servings-input{display:flex;gap:var(--space-sm);align-items:center}.servings-input input{flex:1;text-align:center;font-weight:600}.nutrition-preview{margin:var(--space-xl) 0;padding:var(--space-lg);background:var(--bg-tertiary);border-radius:var(--radius-md)}.nutrition-preview h5{margin-bottom:var(--space-md);color:var(--text-primary)}.nutrition-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:var(--space-md)}.nutrition-item{display:flex;flex-direction:column;gap:var(--space-xs);text-align:center}.nutrition-label{font-size:var(--font-size-xs);color:var(--text-tertiary);font-weight:600;text-transform:uppercase}.nutrition-value{font-size:var(--font-size-xl);font-weight:800;color:var(--text-primary)}@media(max-width:768px){.food-logger{padding:var(--space-md)}.logger-header{flex-direction:column;align-items:flex-start}.logger-actions{width:100%}.logger-actions button{flex:1}.food-nutrition{flex-direction:column;align-items:flex-end;gap:var(--space-xs)}.form-grid{grid-template-columns:1fr}.category-filter{flex-wrap:nowrap}}.barcode-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-lg)}.barcode-modal{width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.barcode-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.barcode-modal-header h3{display:flex;align-items:center;gap:var(--space-sm);margin:0}.barcode-scanner-area{border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--space-lg)}.barcode-scanner-area #barcode-reader{width:100%;border:none!important}.barcode-scanner-area #barcode-reader video{border-radius:var(--radius-lg)}.scanner-hint{text-align:center;margin:var(--space-md) 0 0;font-size:var(--font-size-sm);color:var(--text-tertiary);font-weight:600}.barcode-error{text-align:center;padding:var(--space-lg);background:#f042421a;border-radius:var(--radius-md);margin-bottom:var(--space-lg)}.barcode-error p{color:var(--error);margin-bottom:var(--space-md);font-weight:600}.barcode-loading{text-align:center;padding:var(--space-2xl)}.barcode-loading svg{color:var(--primary-500);margin-bottom:var(--space-md)}.barcode-loading p{color:var(--text-secondary);font-weight:600}.barcode-product{padding:var(--space-lg);background:var(--bg-tertiary);border-radius:var(--radius-lg)}.product-info{display:flex;gap:var(--space-lg);align-items:center;margin-bottom:var(--space-lg)}.product-image{width:80px;height:80px;object-fit:contain;border-radius:var(--radius-md);background:#fff;padding:var(--space-xs)}.product-info h4{margin-bottom:var(--space-xs)}.product-brand{display:block;font-size:var(--font-size-sm);color:var(--text-tertiary);font-style:italic;margin-bottom:var(--space-xs)}.product-serving{display:block;font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:600}.product-nutrition{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-sm);margin-bottom:var(--space-lg)}.product-nutrition .nutrition-item{background:var(--bg-secondary);padding:var(--space-sm);border-radius:var(--radius-md)}.nutri-score{text-align:center;padding:var(--space-sm);margin-bottom:var(--space-lg);font-size:var(--font-size-sm);color:var(--text-secondary)}.nutri-score strong{font-size:var(--font-size-lg);color:var(--primary-500)}.barcode-product .btn-lg{width:100%}.photo-logger{max-width:1200px;margin:0 auto;padding:var(--space-xl)}.logger-header{margin-bottom:var(--space-xl)}.logger-header h1{margin-bottom:var(--space-xs)}.logger-header p{color:var(--text-secondary);margin:0}.upload-section{display:flex;flex-direction:column;gap:var(--space-xl)}.upload-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-lg)}.upload-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);padding:var(--space-2xl);text-align:center;cursor:pointer;border:2px solid transparent;transition:all var(--transition-base)}.upload-card:hover{border-color:var(--primary-500);transform:translateY(-4px);box-shadow:var(--shadow-xl)}.upload-icon{width:80px;height:80px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:#fff}.upload-card h3{margin:0;color:var(--text-primary)}.upload-card p{margin:0;color:var(--text-secondary);font-size:var(--font-size-sm)}.demo-info{padding:var(--space-xl);background:linear-gradient(135deg,var(--primary-50) 0%,var(--bg-secondary) 100%);border:2px solid var(--primary-200)}[data-theme=dark] .demo-info{background:linear-gradient(135deg,var(--primary-900) 0%,var(--bg-secondary) 100%);border-color:var(--primary-700)}.demo-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);color:var(--primary-600)}.demo-header h4{margin:0}.demo-info p{margin-bottom:var(--space-lg);line-height:1.6}.demo-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-sm);margin-bottom:var(--space-lg)}.demo-feature{padding:var(--space-sm);background:var(--bg-secondary);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;color:var(--success)}.demo-note{padding:var(--space-md);background:var(--warning);color:var(--gray-900);border-radius:var(--radius-md);font-size:var(--font-size-sm);line-height:1.5}.demo-note strong{display:block;margin-bottom:var(--space-xs)}.analysis-section{display:flex;flex-direction:column;gap:var(--space-xl)}.photo-preview{padding:var(--space-xl)}.photo-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.photo-header h3{margin:0}.photo-actions{display:flex;gap:var(--space-sm)}.preview-image{width:100%;max-height:400px;object-fit:contain;border-radius:var(--radius-lg);background:var(--bg-tertiary)}.analyzing-card{padding:var(--space-3xl);text-align:center}.analyzing-spinner{display:flex;justify-content:center;margin-bottom:var(--space-xl)}.spinner{width:60px;height:60px;border:4px solid var(--bg-tertiary);border-top-color:var(--primary-500);border-radius:var(--radius-full);animation:spin 1s linear infinite}.analyzing-card h3{margin-bottom:var(--space-sm);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.analyzing-card p{color:var(--text-secondary);margin:0}.detected-foods{padding:var(--space-xl)}.detected-foods h3{margin-bottom:var(--space-xs)}.detected-subtitle{color:var(--text-secondary);margin-bottom:var(--space-lg);font-size:var(--font-size-sm)}.foods-list{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-xl)}.detected-food-item{display:flex;gap:var(--space-md);padding:var(--space-lg);background:var(--bg-tertiary);border:2px solid transparent;border-radius:var(--radius-lg);transition:all var(--transition-fast)}.detected-food-item.selected{background:var(--primary-50);border-color:var(--primary-500)}[data-theme=dark] .detected-food-item.selected{background:var(--primary-900)}.food-select{display:flex;align-items:flex-start;padding-top:var(--space-xs)}.food-checkbox{width:20px;height:20px;cursor:pointer;accent-color:var(--primary-500)}.food-details{flex:1;display:flex;flex-direction:column;gap:var(--space-sm)}.food-name-row{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md)}.food-name{font-weight:700;font-size:var(--font-size-lg);color:var(--text-primary)}.confidence-badge{padding:var(--space-xs) var(--space-sm);background:var(--success);color:#fff;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px}.food-serving{font-size:var(--font-size-sm);color:var(--text-tertiary)}.servings-control{display:flex;align-items:center;gap:var(--space-md);margin-top:var(--space-sm)}.servings-control label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary)}.servings-input{display:flex;gap:var(--space-xs);align-items:center}.servings-input input{width:70px;text-align:center;padding:var(--space-xs) var(--space-sm);border:2px solid var(--border-color);border-radius:var(--radius-md);font-weight:600;background:var(--bg-secondary);color:var(--text-primary)}.servings-input button{width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border:2px solid var(--border-color);color:var(--text-primary)}.food-nutrition{display:flex;gap:var(--space-md);font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);margin-top:var(--space-sm)}.food-nutrition span:first-child{color:var(--primary-500);font-size:var(--font-size-base)}.meal-type-section{margin-bottom:var(--space-lg)}@media(max-width:768px){.photo-logger{padding:var(--space-md)}.upload-cards{grid-template-columns:1fr}.photo-header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.photo-actions{width:100%}.photo-actions button{flex:1}.food-name-row{flex-direction:column;align-items:flex-start}.food-nutrition{flex-wrap:wrap}.demo-features{grid-template-columns:1fr}}.voice-logger{max-width:800px;margin:0 auto;padding:var(--space-xl)}.voice-header{margin-bottom:var(--space-xl)}.voice-header h1{margin-bottom:var(--space-xs)}.voice-header p{margin:0}.voice-mic-section{margin-bottom:var(--space-xl)}.mic-container{display:flex;flex-direction:column;align-items:center;padding:var(--space-2xl) 0}.mic-button{position:relative;width:100px;height:100px;border-radius:50%;border:none;background:var(--gradient-primary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);box-shadow:0 4px 20px #3b82f64d}.mic-button:hover:not(:disabled){transform:scale(1.05);box-shadow:0 6px 30px #3b82f666}.mic-button:disabled{opacity:.5;cursor:not-allowed}.mic-button.listening{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 20px #ef444466;animation:mic-breathe 1.5s ease-in-out infinite}@keyframes mic-breathe{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.mic-pulse-ring{position:absolute;border-radius:50%;border:2px solid rgba(239,68,68,.3);animation:pulse-ring 2s cubic-bezier(0,0,.2,1) infinite}.ring-1{width:130px;height:130px;animation-delay:0s}.ring-2{width:160px;height:160px;animation-delay:.5s}.ring-3{width:190px;height:190px;animation-delay:1s}@keyframes pulse-ring{0%{opacity:.8;transform:scale(.8)}to{opacity:0;transform:scale(1.2)}}.mic-label{margin-top:var(--space-xl);font-weight:700;font-size:var(--font-size-lg);color:var(--text-primary);text-align:center}.mic-hint{margin-top:var(--space-sm);font-size:var(--font-size-sm);color:var(--text-tertiary);font-style:italic;text-align:center}.transcript-section{margin-top:var(--space-xl);padding:var(--space-lg);background:var(--bg-tertiary);border-radius:var(--radius-lg)}.transcript-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.transcript-header h4{display:flex;align-items:center;gap:var(--space-sm);margin:0}.transcript-text{font-size:var(--font-size-lg);line-height:1.8;min-height:40px}.final-text{color:var(--text-primary)}.interim-text{color:var(--text-tertiary);font-style:italic}.voice-error{margin-top:var(--space-lg);padding:var(--space-md);background:#f042421a;border-radius:var(--radius-md);text-align:center}.voice-error p{color:var(--error);font-weight:600;margin:0}.voice-actions{display:flex;justify-content:center;margin-top:var(--space-xl)}.meal-selector{margin-bottom:var(--space-xl)}.meal-selector h4{margin-bottom:var(--space-md)}.meal-options{display:flex;gap:var(--space-sm);flex-wrap:wrap}.meal-btn{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border:2px solid var(--border-color);border-radius:var(--radius-full);background:var(--bg-secondary);color:var(--text-secondary);font-weight:600;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast)}.meal-btn:hover{border-color:var(--primary-400);color:var(--primary-500)}.meal-btn.active{background:var(--gradient-primary);color:#fff;border-color:transparent}.parsed-foods{margin-bottom:var(--space-xl)}.parsed-foods h3{margin-bottom:var(--space-lg)}.parsed-food-list{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-xl)}.parsed-food-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);border:2px solid transparent;transition:all var(--transition-fast)}.parsed-food-item.selected{border-color:var(--primary-300);background:var(--primary-50)}[data-theme=dark] .parsed-food-item.selected{background:var(--primary-900)}.check-btn{width:28px;height:28px;border-radius:var(--radius-md);border:2px solid var(--border-color);background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.check-btn.checked{background:var(--primary-500);border-color:var(--primary-500);color:#fff}.parsed-food-info{flex:1;min-width:0}.parsed-food-name{display:block;font-weight:700;color:var(--text-primary);font-size:var(--font-size-base)}.parsed-food-search{display:block;font-size:var(--font-size-xs);color:var(--text-tertiary);margin-top:2px}.parsed-food-macros{display:flex;gap:var(--space-md);margin-top:var(--space-xs);font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:600}.parsed-food-controls{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.servings-mini{display:flex;align-items:center;gap:var(--space-xs);font-weight:700;font-size:var(--font-size-sm)}.remove-btn{color:var(--error)!important}.log-all-btn{width:100%}@media(max-width:768px){.voice-logger{padding:var(--space-md)}.mic-button{width:80px;height:80px}.ring-1{width:110px;height:110px}.ring-2{width:135px;height:135px}.ring-3{width:160px;height:160px}.parsed-food-item{flex-wrap:wrap}.parsed-food-macros{flex-wrap:wrap;gap:var(--space-sm)}.meal-options{justify-content:center}}.activity-tracker{max-width:1200px;margin:0 auto;padding:var(--space-xl)}.tracker-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-xl);flex-wrap:wrap;gap:var(--space-md)}.tracker-header h1{margin-bottom:var(--space-xs)}.tracker-header p{color:var(--text-secondary);margin:0}.tracker-actions{display:flex;gap:var(--space-sm)}.activity-summary{padding:var(--space-xl);margin-bottom:var(--space-xl)}.activity-summary h3{margin-bottom:var(--space-lg)}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-lg)}.summary-stat{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-lg)}.stat-icon{font-size:2.5rem}.stat-content{display:flex;flex-direction:column;gap:var(--space-xs)}.stat-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:600}.stat-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--primary-500)}.steps-input{padding:var(--space-xl);margin-bottom:var(--space-xl)}.steps-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.steps-header h3{margin:0}.steps-form{display:flex;flex-direction:column;gap:var(--space-lg)}.steps-estimate{margin-top:var(--space-sm);color:var(--success);font-weight:600;font-size:var(--font-size-sm)}.device-integration{padding:var(--space-xl);margin-bottom:var(--space-xl);background:linear-gradient(135deg,var(--primary-50) 0%,var(--bg-secondary) 100%);border:2px solid var(--primary-200)}[data-theme=dark] .device-integration{background:linear-gradient(135deg,var(--primary-900) 0%,var(--bg-secondary) 100%);border-color:var(--primary-700)}.integration-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);color:var(--primary-600)}.integration-header h4{margin:0}.device-integration>p{margin-bottom:var(--space-lg);line-height:1.6}.integration-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}.integration-btn{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-lg);background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:not-allowed;opacity:.7;transition:all var(--transition-base);position:relative}.integration-logo{width:48px;height:48px;object-fit:contain}.apple-health-icon,.fitbit-icon{font-size:3rem}.coming-soon-badge{position:absolute;top:var(--space-xs);right:var(--space-xs);padding:2px 8px;background:var(--warning);color:var(--gray-900);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase}.integration-note{padding:var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-md);font-size:var(--font-size-sm);margin:0}.integration-setup{display:flex;flex-direction:column;gap:var(--space-md);align-items:center;text-align:center}.setup-message{padding:var(--space-md);background:var(--warning);color:var(--gray-900);border-radius:var(--radius-md);font-weight:600}.google-connected,.google-disconnected{display:flex;flex-direction:column;gap:var(--space-lg)}.google-profile{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-lg)}.profile-image{width:48px;height:48px;border-radius:50%;border:2px solid var(--primary-500)}.profile-info{flex:1;display:flex;flex-direction:column;gap:var(--space-xs)}.profile-name{font-weight:700;color:var(--text-primary)}.profile-email{font-size:var(--font-size-sm);color:var(--text-secondary)}.last-sync{font-size:var(--font-size-xs);color:var(--success);font-weight:600}.sync-error{padding:var(--space-md);background:var(--error);color:#fff;border-radius:var(--radius-md);font-weight:600}.google-signin-btn{display:flex;align-items:center;gap:var(--space-md);justify-content:center;background:#fff;color:var(--gray-900);border:2px solid var(--border-color)}.google-signin-btn:hover{background:var(--gray-100);border-color:var(--primary-500)}.google-logo{width:24px;height:24px}.sync-features{padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md)}.sync-features h5{margin:0 0 var(--space-sm) 0;font-size:var(--font-size-base)}.sync-features ul{margin:0;padding-left:var(--space-lg);list-style:none}.sync-features li{padding:var(--space-xs) 0;font-size:var(--font-size-sm)}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.exercise-search{padding:var(--space-xl);margin-bottom:var(--space-xl)}.exercise-search h3{margin-bottom:var(--space-lg)}.exercise-results{display:flex;flex-direction:column;gap:var(--space-sm);max-height:400px;overflow-y:auto}.exercise-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border:2px solid transparent;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.exercise-item:hover{background:var(--bg-secondary);border-color:var(--primary-500);transform:translate(4px)}.exercise-item.selected{background:var(--primary-50);border-color:var(--primary-500)}[data-theme=dark] .exercise-item.selected{background:var(--primary-900)}.exercise-icon{font-size:2rem;flex-shrink:0}.exercise-info{flex:1;display:flex;flex-direction:column;gap:var(--space-xs)}.exercise-name{font-weight:600;color:var(--text-primary)}.exercise-met{font-size:var(--font-size-sm);color:var(--text-tertiary)}.exercise-arrow{color:var(--text-tertiary);flex-shrink:0}.selected-exercise{padding:var(--space-xl)}.selected-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.selected-header h3{margin:0}.selected-details{display:flex;flex-direction:column;gap:var(--space-xl)}.exercise-display{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);padding:var(--space-xl);background:var(--bg-tertiary);border-radius:var(--radius-lg)}.exercise-display-icon{font-size:4rem}.exercise-display h4{margin:0;text-align:center}.duration-input{display:flex;gap:var(--space-sm);align-items:center}.duration-input input{flex:1;text-align:center;font-weight:600;font-size:var(--font-size-lg)}.calories-estimate{padding:var(--space-xl);background:linear-gradient(135deg,var(--success) 0%,var(--primary-500) 100%);border-radius:var(--radius-lg);text-align:center;color:#fff}.calories-estimate h5{margin:0 0 var(--space-md) 0;font-size:var(--font-size-base);font-weight:600;opacity:.9}.calories-display{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);margin-bottom:var(--space-md)}.calories-number{font-size:3rem;font-weight:700}.calories-label{font-size:var(--font-size-sm);opacity:.9}.estimate-note{font-size:var(--font-size-sm);opacity:.8;margin:0}@media(max-width:768px){.activity-tracker{padding:var(--space-md)}.tracker-header{flex-direction:column;align-items:flex-start}.summary-stats,.integration-options{grid-template-columns:1fr}.duration-input{flex-direction:column}.duration-input button{width:100%}}.recipe-manager{max-width:1400px;margin:0 auto;padding:var(--space-xl)}.recipe-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl)}.recipe-header h1{margin:0;font-size:var(--font-size-2xl);background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.recipe-header p{margin:var(--space-xs) 0 0 0;color:var(--text-secondary)}.recipe-library{display:flex;flex-direction:column;gap:var(--space-xl)}.recipe-search{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg)}.recipe-search .search-input{flex:1;border:none;background:transparent;font-size:var(--font-size-base);color:var(--text-primary)}.recipe-search .search-input:focus{outline:none}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3xl);text-align:center;gap:var(--space-lg)}.empty-state svg{color:var(--text-tertiary)}.empty-state h3{margin:0;font-size:var(--font-size-xl)}.empty-state p{margin:0;color:var(--text-secondary)}.recipe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-xl)}.recipe-card{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-xl);transition:transform .2s ease,box-shadow .2s ease}.recipe-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.recipe-card-header{display:flex;justify-content:space-between;align-items:center}.recipe-category{font-size:var(--font-size-2xl)}.favorite-btn{background:none;border:none;cursor:pointer;color:var(--text-tertiary);transition:color .2s ease;padding:var(--space-xs)}.favorite-btn:hover,.favorite-btn.active{color:var(--warning)}.recipe-card h3{margin:0;font-size:var(--font-size-lg);color:var(--text-primary)}.recipe-description{margin:0;color:var(--text-secondary);font-size:var(--font-size-sm);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.recipe-meta{display:flex;gap:var(--space-lg);color:var(--text-secondary);font-size:var(--font-size-sm)}.recipe-meta span{display:flex;align-items:center;gap:var(--space-xs)}.recipe-nutrition{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-sm);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md)}.nutrition-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs)}.nutrition-item .label{font-size:var(--font-size-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.nutrition-item .value{font-size:var(--font-size-base);font-weight:700;color:var(--text-primary)}.recipe-actions{display:flex;gap:var(--space-sm);margin-top:auto}.recipe-actions .btn-sm{flex:1}.recipe-form{display:flex;flex-direction:column;gap:var(--space-xl);max-width:900px;margin:0 auto}.form-section{padding:var(--space-xl)}.form-section h3{margin:0 0 var(--space-lg) 0;font-size:var(--font-size-xl)}.form-group{display:flex;flex-direction:column;gap:var(--space-sm)}.form-label{font-weight:600;color:var(--text-primary);font-size:var(--font-size-sm)}.form-input{padding:var(--space-md);border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-size-base);background:var(--bg-primary);color:var(--text-primary);transition:border-color .2s ease}.form-input:focus{outline:none;border-color:var(--primary-500)}.form-input-sm{padding:var(--space-sm);border:2px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-sm);background:var(--bg-primary);color:var(--text-primary);width:80px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-lg)}.ingredient-search{display:flex;gap:var(--space-md);margin-bottom:var(--space-lg)}.ingredient-results{display:flex;flex-direction:column;gap:var(--space-xs);max-height:300px;overflow-y:auto;margin-bottom:var(--space-lg)}.ingredient-result{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);cursor:pointer;transition:background .2s ease}.ingredient-result:hover{background:var(--bg-hover)}.ingredients-list{display:flex;flex-direction:column;gap:var(--space-sm);margin-top:var(--space-lg)}.ingredient-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md)}.ingredient-name{flex:1;font-weight:600}.ingredient-controls{display:flex;align-items:center;gap:var(--space-sm)}.unit{color:var(--text-secondary);font-size:var(--font-size-sm)}.nutrition-summary{margin-top:var(--space-xl);padding:var(--space-lg);background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);border-radius:var(--radius-lg);color:#fff}.nutrition-summary h4{margin:0 0 var(--space-md) 0;font-size:var(--font-size-lg)}.nutrition-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md);margin-bottom:var(--space-md)}.nutrition-grid div{display:flex;flex-direction:column;gap:var(--space-xs)}.nutrition-grid span{font-size:var(--font-size-sm);opacity:.9}.nutrition-grid strong{font-size:var(--font-size-lg)}.per-serving{margin:var(--space-md) 0 0 0;font-size:var(--font-size-sm);opacity:.9;text-align:center}.recipe-detail{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:var(--space-xl)}.detail-card{padding:var(--space-2xl)}.detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-xl)}.detail-header h2{margin:0;font-size:var(--font-size-2xl)}.detail-header p{margin:var(--space-sm) 0 0 0;color:var(--text-secondary)}.favorite-btn-large{background:none;border:none;cursor:pointer;color:var(--text-tertiary);transition:color .2s ease;padding:var(--space-sm)}.favorite-btn-large:hover,.favorite-btn-large.active{color:var(--warning)}.detail-meta{display:flex;gap:var(--space-2xl);margin-bottom:var(--space-xl);padding-bottom:var(--space-xl);border-bottom:2px solid var(--border-color)}.meta-item{display:flex;align-items:center;gap:var(--space-sm);color:var(--text-secondary)}.meta-icon{font-size:var(--font-size-xl)}.detail-nutrition{margin-bottom:var(--space-xl)}.detail-nutrition h3{margin:0 0 var(--space-lg) 0;font-size:var(--font-size-xl)}.nutrition-detail-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-lg)}.nutrition-detail-item{display:flex;flex-direction:column;align-items:center;padding:var(--space-lg);background:var(--bg-tertiary);border-radius:var(--radius-lg);gap:var(--space-sm)}.nutrition-detail-item .label{font-size:var(--font-size-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.nutrition-detail-item .value{font-size:var(--font-size-2xl);font-weight:700;color:var(--text-primary)}.detail-ingredients{margin-bottom:var(--space-xl)}.detail-ingredients h3{margin:0 0 var(--space-lg) 0;font-size:var(--font-size-xl)}.detail-ingredients ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-sm)}.detail-ingredients li{padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md)}.detail-instructions{margin-bottom:var(--space-xl)}.detail-instructions h3{margin:0 0 var(--space-lg) 0;font-size:var(--font-size-xl)}.detail-instructions p{margin:0;line-height:1.8;white-space:pre-wrap}.detail-actions{display:flex;gap:var(--space-md)}.detail-actions .btn-lg{flex:1}@media(max-width:768px){.recipe-manager{padding:var(--space-lg)}.recipe-header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.recipe-grid,.form-row{grid-template-columns:1fr}.recipe-nutrition,.nutrition-grid,.nutrition-detail-grid{grid-template-columns:repeat(2,1fr)}.detail-meta{flex-direction:column;gap:var(--space-md)}.detail-actions{flex-direction:column}}.progress-charts{max-width:1200px;margin:0 auto;padding:var(--space-xl)}.charts-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-xl);flex-wrap:wrap;gap:var(--space-md)}.charts-header h1{margin-bottom:var(--space-xs)}.charts-header p{margin:0}.weight-input-card{margin-bottom:var(--space-xl)}.weight-input-card h3{margin-bottom:var(--space-md)}.weight-input-row{display:flex;gap:var(--space-md);align-items:center}.weight-input-row .form-input{max-width:250px}.time-range-selector{display:flex;gap:var(--space-sm);margin-bottom:var(--space-xl);flex-wrap:wrap}.range-btn{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-sm);font-weight:600;border:2px solid var(--border-color);border-radius:var(--radius-full);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.range-btn:hover{border-color:var(--primary-400);color:var(--primary-500)}.range-btn.active{background:var(--gradient-primary);color:#fff;border-color:transparent}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);margin-bottom:var(--space-xl)}.quick-stat{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg)!important}.stat-icon-wrap{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.quick-stat .stat-label{display:block;font-size:var(--font-size-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.quick-stat .stat-val{display:block;font-size:var(--font-size-xl);font-weight:800;color:var(--text-primary);margin-top:2px}.chart-tabs{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg);overflow-x:auto;padding-bottom:var(--space-xs)}.chart-tab{padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-sm);font-weight:600;border:none;border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;box-shadow:var(--shadow-sm)}.chart-tab:hover{background:var(--bg-tertiary);color:var(--text-primary)}.chart-tab.active{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md)}.chart-container{margin-bottom:var(--space-xl)}.chart-wrapper h3{margin-bottom:var(--space-xs)}.chart-wrapper>p{color:var(--text-tertiary);font-size:var(--font-size-sm);margin-bottom:var(--space-lg)}.chart-area{height:350px;position:relative}.chart-area-doughnut{height:300px;max-width:400px;margin:0 auto}.macro-summary{display:flex;justify-content:center;gap:var(--space-xl);margin-top:var(--space-lg);flex-wrap:wrap}.macro-stat{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);color:var(--text-secondary)}.macro-dot{width:12px;height:12px;border-radius:var(--radius-full);flex-shrink:0}.empty-chart{text-align:center;padding:var(--space-3xl) var(--space-xl);color:var(--text-tertiary)}.empty-chart svg{margin-bottom:var(--space-lg);opacity:.5}.empty-chart h4{margin-bottom:var(--space-sm);color:var(--text-primary)}.empty-chart p,.goal-progress h3{margin-bottom:var(--space-lg)}.goal-items{display:flex;flex-direction:column;gap:var(--space-lg)}.goal-item .goal-info{display:flex;justify-content:space-between;margin-bottom:var(--space-sm)}.goal-label{font-weight:600;font-size:var(--font-size-sm);color:var(--text-primary)}.goal-value{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:500}@media(max-width:768px){.charts-header{flex-direction:column}.stats-row{grid-template-columns:repeat(2,1fr)}.chart-area{height:280px}.macro-summary{flex-direction:column;align-items:center}}@media(max-width:480px){.stats-row{grid-template-columns:1fr}.time-range-selector{justify-content:center}}.fasting-timer{max-width:700px;margin:0 auto;padding:var(--space-xl)}.fasting-header{margin-bottom:var(--space-xl)}.fasting-header h1{margin-bottom:var(--space-xs)}.fasting-header p{margin:0}.preset-selector{margin-bottom:var(--space-xl);padding:0!important;overflow:hidden}.preset-dropdown-btn{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-lg) var(--space-xl);border:none;background:transparent;cursor:pointer;text-align:left;color:var(--text-primary)}.preset-dropdown-btn:disabled{opacity:.6;cursor:not-allowed}.preset-dropdown-btn svg{color:var(--text-tertiary);transition:transform var(--transition-fast)}.preset-dropdown-btn svg.rotated{transform:rotate(180deg)}.preset-name{display:block;font-weight:800;font-size:var(--font-size-xl)}.preset-desc{display:block;font-size:var(--font-size-sm);color:var(--text-tertiary);margin-top:2px}.preset-list{border-top:1px solid var(--border-color)}.preset-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-md) var(--space-xl);border:none;background:transparent;cursor:pointer;text-align:left;color:var(--text-primary);transition:background var(--transition-fast);border-bottom:1px solid var(--border-color)}.preset-option:last-of-type{border-bottom:none}.preset-option:hover{background:var(--bg-tertiary)}.preset-option.active{background:var(--primary-50)}[data-theme=dark] .preset-option.active{background:var(--primary-900)}.preset-option-name{display:block;font-weight:700}.preset-option-desc{display:block;font-size:var(--font-size-xs);color:var(--text-tertiary)}.preset-hours{font-weight:800;font-size:var(--font-size-lg);color:var(--primary-500)}.custom-input-row{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-xl);background:var(--bg-tertiary)}.custom-input-row label{font-weight:600;font-size:var(--font-size-sm);white-space:nowrap}.custom-input-row .form-input{max-width:80px;text-align:center}.timer-ring-container{display:flex;flex-direction:column;align-items:center;padding:var(--space-2xl)!important;margin-bottom:var(--space-xl)}.timer-ring{position:relative;width:280px;height:280px;margin-bottom:var(--space-xl)}.timer-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-xs)}.timer-emoji{font-size:3rem}.timer-label{font-size:var(--font-size-sm);color:var(--text-tertiary);text-transform:uppercase;font-weight:700;letter-spacing:1px}.timer-digits{display:flex;align-items:baseline;font-size:2.5rem;font-weight:800;color:var(--text-primary);font-variant-numeric:tabular-nums}.timer-sep{color:var(--text-tertiary);padding:0 2px;animation:blink 1s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.timer-elapsed{font-size:var(--font-size-sm);color:var(--text-tertiary);font-weight:600}.timer-hint{font-size:var(--font-size-sm);color:var(--text-tertiary);margin-top:var(--space-sm)}.timer-status{font-size:var(--font-size-xl);font-weight:800}.timer-status.success{color:var(--success)}.timer-controls{display:flex;gap:var(--space-md);flex-wrap:wrap;justify-content:center}.timer-progress-info{margin-top:var(--space-lg);font-size:var(--font-size-sm);color:var(--text-tertiary);font-weight:700}.fasting-history h3{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-lg)}.history-list{display:flex;flex-direction:column;gap:var(--space-sm)}.history-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);border-left:4px solid var(--warning)}.history-item.completed{border-left-color:var(--success)}.history-preset{font-weight:700;font-size:var(--font-size-base)}.history-date{display:block;font-size:var(--font-size-xs);color:var(--text-tertiary);margin-top:2px}.history-stats{display:flex;align-items:center;gap:var(--space-md)}.history-duration{font-weight:700;font-size:var(--font-size-base);color:var(--text-primary)}.history-badge{padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:700}@media(max-width:480px){.timer-ring{width:240px;height:240px}.timer-ring svg{width:240px;height:240px}.timer-digits{font-size:2rem}.history-item{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}}.adaptive-coach{max-width:900px;margin:0 auto;padding:var(--space-xl)}.coach-header{margin-bottom:var(--space-xl)}.coach-header h1{margin-bottom:var(--space-xs)}.coach-header p{margin:0}.coach-range{display:flex;gap:var(--space-sm);margin-bottom:var(--space-xl)}.coach-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-md);margin-bottom:var(--space-xl)}.coach-stat{text-align:center;padding:var(--space-lg)!important}.coach-stat-label{display:block;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);font-weight:700;margin-bottom:var(--space-xs)}.coach-stat-value{display:block;font-size:var(--font-size-2xl);font-weight:800;color:var(--text-primary)}.coach-stat-vs{display:block;font-size:var(--font-size-xs);color:var(--text-tertiary);margin-top:var(--space-xs)}.coach-stat-vs .over{color:var(--error);font-weight:700}.coach-stat-vs .under{color:var(--success);font-weight:700}.calorie-adjustment{margin-bottom:var(--space-xl);background:linear-gradient(135deg,#06a8f90d,#9952e00d);border:2px solid var(--primary-200)}[data-theme=dark] .calorie-adjustment{border-color:var(--primary-800)}.adjust-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);color:var(--primary-500)}.adjust-header h3{margin:0}.calorie-adjustment>p{margin-bottom:var(--space-lg)}.adjust-visual{display:flex;align-items:center;justify-content:center;gap:var(--space-xl)}.adjust-from,.adjust-to{text-align:center;padding:var(--space-md) var(--space-xl);border-radius:var(--radius-lg)}.adjust-from{background:var(--bg-tertiary)}.adjust-to{background:var(--primary-50);border:2px solid var(--primary-300)}[data-theme=dark] .adjust-to{background:var(--primary-900)}.adjust-from span,.adjust-to span{display:block;font-size:var(--font-size-xs);text-transform:uppercase;color:var(--text-tertiary);font-weight:700;margin-bottom:var(--space-xs)}.adjust-from strong,.adjust-to strong{font-size:var(--font-size-xl)}.coach-recommendations h2{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-lg)}.recs-list{display:flex;flex-direction:column;gap:var(--space-md)}.rec-card{display:flex;gap:var(--space-lg);padding:var(--space-lg)!important;border-left:4px solid var(--primary-500)}.rec-card.success{border-left-color:var(--success)}.rec-card.warning{border-left-color:var(--warning)}.rec-card.tip{border-left-color:var(--info)}.rec-card.info{border-left-color:var(--primary-400)}.rec-icon{font-size:1.5rem;flex-shrink:0;padding-top:2px}.rec-content h4{margin-bottom:var(--space-sm)}.rec-detail{font-size:var(--font-size-sm);margin-bottom:var(--space-sm)!important}.rec-action{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0!important}@media(max-width:768px){.coach-stats{grid-template-columns:repeat(2,1fr)}.adjust-visual{flex-direction:column;gap:var(--space-sm)}.adjust-visual svg{transform:rotate(90deg)}}.meal-planner{max-width:900px;margin:0 auto;padding:var(--space-xl)}.planner-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-md);margin-bottom:var(--space-xl)}.planner-header h1{margin-bottom:var(--space-xs)}.planner-header p{margin:0}.grocery-list{margin-bottom:var(--space-xl)}.grocery-list h3{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-lg)}.grocery-items{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--space-sm)}.grocery-item{display:flex;justify-content:space-between;padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md)}.grocery-name{font-weight:700}.grocery-details{font-size:var(--font-size-sm);color:var(--text-tertiary)}.empty-grocery{text-align:center;color:var(--text-tertiary)}.day-tabs{display:flex;gap:var(--space-xs);margin-bottom:var(--space-xl);overflow-x:auto;padding-bottom:var(--space-xs)}.day-tab{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-sm) var(--space-lg);border:2px solid transparent;border-radius:var(--radius-md);background:var(--bg-tertiary);cursor:pointer;font-weight:700;color:var(--text-secondary);min-width:70px;transition:all var(--transition-fast)}.day-tab:hover{background:var(--bg-primary)}.day-tab.active{background:var(--primary-500);color:#fff;border-color:var(--primary-600)}.day-tab.has-items .day-cal{font-size:var(--font-size-xs);opacity:.8}.day-short{font-size:var(--font-size-sm)}.day-summary{margin-bottom:var(--space-xl)}.day-summary-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.day-actions{display:flex;gap:var(--space-sm)}.day-macros{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md);margin-bottom:var(--space-lg)}.day-macro{text-align:center}.macro-val{display:block;font-size:var(--font-size-xl);font-weight:800;color:var(--text-primary)}.macro-lbl{display:block;font-size:var(--font-size-xs);color:var(--text-tertiary);text-transform:uppercase;font-weight:700}.calorie-bar{position:relative;height:28px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.calorie-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width var(--transition-base)}.calorie-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);font-weight:700;color:var(--text-primary);mix-blend-mode:difference}.meal-section{margin-bottom:var(--space-md)}.meal-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.meal-section-header h4{margin:0}.add-food-search{margin-bottom:var(--space-md);position:relative}.search-drop{position:absolute;top:100%;left:0;right:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:0 0 var(--radius-md) var(--radius-md);box-shadow:var(--shadow-lg);max-height:250px;overflow-y:auto;z-index:10}.search-drop-item{display:flex;justify-content:space-between;width:100%;padding:var(--space-sm) var(--space-md);border:none;background:transparent;cursor:pointer;text-align:left;color:var(--text-primary);font-size:var(--font-size-sm);transition:background var(--transition-fast)}.search-drop-item:hover{background:var(--bg-tertiary)}.search-drop-cal{color:var(--primary-500);font-weight:700}.meal-empty{text-align:center;color:var(--text-tertiary);font-size:var(--font-size-sm);padding:var(--space-md)}.meal-foods{display:flex;flex-direction:column;gap:var(--space-xs)}.planned-food{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md)}.planned-food-info{flex:1;min-width:0}.planned-food-name{display:block;font-weight:700;font-size:var(--font-size-sm)}.planned-food-serving{font-size:var(--font-size-xs);color:var(--text-tertiary)}.planned-food-macros{display:flex;gap:var(--space-sm);font-size:var(--font-size-xs);color:var(--text-secondary);font-weight:600;flex-shrink:0}@media(max-width:768px){.day-macros{grid-template-columns:repeat(2,1fr)}.planned-food{flex-wrap:wrap}.planned-food-macros{width:100%;justify-content:space-around}}.social-feed{max-width:700px;margin:0 auto;padding:var(--space-xl)}.social-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl)}.social-header h1{margin-bottom:var(--space-xs)}.social-header p{margin:0}.social-tabs{display:flex;gap:var(--space-sm);margin-bottom:var(--space-xl);border-bottom:2px solid var(--border-color);padding-bottom:var(--space-sm)}.social-tab{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-lg);border:none;background:transparent;color:var(--text-secondary);font-weight:700;font-size:var(--font-size-sm);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.social-tab:hover{background:var(--bg-tertiary)}.social-tab.active{background:var(--primary-500);color:#fff}.new-post{margin-bottom:var(--space-xl)}.new-post textarea{resize:vertical;min-height:80px;margin-bottom:var(--space-md)}.new-post-actions{display:flex;justify-content:flex-end}.posts-list{display:flex;flex-direction:column;gap:var(--space-lg)}.post-card{padding:var(--space-lg)!important}.post-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.post-user{display:flex;align-items:center;gap:var(--space-sm)}.user-avatar{font-size:2rem}.user-name{display:block;font-weight:700}.user-level{display:block;font-size:var(--font-size-xs);color:var(--primary-500);font-weight:600}.post-time{font-size:var(--font-size-xs);color:var(--text-tertiary)}.post-content{margin-bottom:var(--space-md);line-height:1.6}.post-badge{display:inline-block;padding:var(--space-xs) var(--space-md);background:var(--primary-50);border:1px solid var(--primary-200);border-radius:var(--radius-full);font-weight:700;font-size:var(--font-size-sm);margin-bottom:var(--space-md)}[data-theme=dark] .post-badge{background:var(--primary-900);border-color:var(--primary-700)}.post-actions{display:flex;gap:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--border-color)}.post-action{display:flex;align-items:center;gap:var(--space-xs);background:none;border:none;color:var(--text-tertiary);font-weight:600;font-size:var(--font-size-sm);cursor:pointer;padding:var(--space-xs);border-radius:var(--radius-md);transition:all var(--transition-fast)}.post-action:hover{color:var(--text-primary);background:var(--bg-tertiary)}.post-action.liked{color:#ef4444}.challenges-list{display:flex;flex-direction:column;gap:var(--space-md)}.challenge-card{padding:var(--space-lg)!important}.challenge-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md)}.challenge-emoji{font-size:2rem}.challenge-header h4{margin-bottom:2px}.challenge-header p{font-size:var(--font-size-sm);color:var(--text-tertiary);margin:0}.challenge-stats{display:flex;justify-content:space-between;align-items:center}.challenge-participants{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm);color:var(--text-tertiary);font-weight:600}.challenge-progress{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);font-weight:600}.challenge-bar{width:100px;height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.challenge-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full)}.leaderboard h3{margin-bottom:var(--space-lg)}.leaderboard-list{display:flex;flex-direction:column;gap:var(--space-sm)}.lb-entry{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);transition:transform var(--transition-fast)}.lb-entry:hover{transform:translate(4px)}.lb-entry.you{background:var(--primary-50);border:2px solid var(--primary-300)}[data-theme=dark] .lb-entry.you{background:var(--primary-900)}.lb-rank{font-size:var(--font-size-lg);font-weight:800;min-width:32px;text-align:center}.lb-avatar{font-size:1.5rem}.lb-info{flex:1}.lb-name{display:block;font-weight:700}.lb-streak{display:block;font-size:var(--font-size-xs);color:var(--text-tertiary)}.lb-points{font-weight:800;color:var(--primary-500);font-size:var(--font-size-lg)}@media(max-width:480px){.social-tabs{overflow-x:auto}.challenge-stats{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}}.settings{max-width:900px;margin:0 auto;padding:var(--space-xl)}.settings-header{margin-bottom:var(--space-xl)}.settings-header h1{margin-bottom:var(--space-xs)}.settings-header p{color:var(--text-secondary);margin:0}.settings-section{margin-bottom:var(--space-xl);padding:var(--space-xl)}.section-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);color:var(--primary-500)}.section-header h3{margin:0}.section-description{color:var(--text-secondary);margin-bottom:var(--space-lg)}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-lg)}.bmi-display{margin-top:var(--space-xl);padding:var(--space-xl);background:var(--bg-tertiary);border-radius:var(--radius-lg);display:flex;justify-content:space-around;align-items:center}.bmi-value{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs)}.bmi-number{font-size:var(--font-size-4xl);font-weight:800;color:var(--text-primary)}.bmi-label{font-size:var(--font-size-sm);color:var(--text-tertiary);text-transform:uppercase;font-weight:600}.bmi-category{font-size:var(--font-size-xl);font-weight:700}.macros-section{margin-top:var(--space-xl);padding-top:var(--space-xl);border-top:1px solid var(--border-color)}.macros-section h4{margin-bottom:var(--space-lg);color:var(--text-primary)}.data-actions{display:flex;gap:var(--space-md);flex-wrap:wrap}@media(max-width:768px){.settings{padding:var(--space-md)}.form-grid{grid-template-columns:1fr}.bmi-display{flex-direction:column;gap:var(--space-lg)}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-xl);background:var(--gradient-bg)}.auth-container{width:100%;max-width:440px}.auth-card{padding:var(--space-2xl)!important}.auth-logo{text-align:center;margin-bottom:var(--space-2xl)}.logo-icon-large{font-size:4rem;display:block;margin-bottom:var(--space-md)}.auth-logo h1{font-size:var(--font-size-4xl);margin-bottom:var(--space-sm)}.auth-logo p{color:var(--text-secondary);margin:0}.auth-form{display:flex;flex-direction:column;gap:var(--space-md)}.input-with-icon{position:relative;display:flex;align-items:center}.input-with-icon svg{position:absolute;left:var(--space-md);color:var(--text-tertiary);z-index:1}.input-with-icon .form-input{padding-left:calc(var(--space-md) + 28px)}.toggle-password{position:absolute;right:var(--space-md);background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-xs);z-index:1}.toggle-password:hover{color:var(--text-primary)}.auth-error{padding:var(--space-sm) var(--space-md);background:#f042421a;color:var(--error);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;text-align:center}.auth-success{padding:var(--space-sm) var(--space-md);background:#26d9711a;color:var(--success);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;text-align:center}.auth-btn{width:100%;margin-top:var(--space-sm)}.forgot-link{display:block;text-align:center;margin-top:var(--space-md);font-size:var(--font-size-sm);color:var(--primary-500);background:none;border:none;cursor:pointer;font-weight:600}.forgot-link:hover{color:var(--primary-600);text-decoration:underline}.auth-divider{display:flex;align-items:center;margin:var(--space-xl) 0;gap:var(--space-md)}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.auth-divider span{font-size:var(--font-size-sm);color:var(--text-tertiary);font-weight:600;text-transform:uppercase}.google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-md)}.auth-switch{text-align:center;margin-top:var(--space-xl);font-size:var(--font-size-sm);color:var(--text-secondary)}.auth-switch button{background:none;border:none;color:var(--primary-500);font-weight:700;cursor:pointer;font-size:var(--font-size-sm)}.auth-switch button:hover{text-decoration:underline}.skip-btn{display:block;width:100%;text-align:center;margin-top:var(--space-md);padding:var(--space-sm);background:none;border:none;color:var(--text-tertiary);font-size:var(--font-size-sm);cursor:pointer;font-weight:600;transition:color var(--transition-fast)}.skip-btn:hover{color:var(--text-primary)}@media(max-width:480px){.auth-card{padding:var(--space-xl)!important}.logo-icon-large{font-size:3rem}}
