:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-tertiary: #e9ecef;--text-primary: #2c3e50;--text-secondary: #6c757d;--text-tertiary: #95a5a6;--border-color: #dee2e6;--border-light: #e9ecef;--accent-primary: #4CAF50;--accent-secondary: #2196F3;--accent-tertiary: #FF9800;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .15);--card-bg: #ffffff;--card-hover: #f8f9fa;--input-bg: #ffffff;--input-border: #ced4da;--success: #28a745;--danger: #dc3545;--warning: #ffc107;--info: #17a2b8}[data-theme=dark]{--bg-primary: #1a1a1a;--bg-secondary: #242424;--bg-tertiary: #2d2d2d;--text-primary: #e0e0e0;--text-secondary: #b0b0b0;--text-tertiary: #808080;--border-color: #3a3a3a;--border-light: #2d2d2d;--accent-primary: #66BB6A;--accent-secondary: #42A5F5;--accent-tertiary: #FFA726;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .5);--card-bg: #242424;--card-hover: #2d2d2d;--input-bg: #2d2d2d;--input-border: #3a3a3a;--success: #4caf50;--danger: #f44336;--warning: #ffc107;--info: #2196f3}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}[data-theme=dark] .btn-primary,[data-theme=dark] .btn-action,[data-theme=dark] .btn-regenerate,[data-theme=dark] .btn-shopping,[data-theme=dark] .btn-print,[data-theme=dark] .btn-share{color:#fff!important}.btn-secondary{background:var(--card-bg)!important;color:var(--text-primary)!important;border:2px solid var(--border-color)!important}[data-theme=dark] .btn-secondary{background:var(--bg-tertiary)!important;color:var(--text-primary)!important;border-color:var(--border-color)!important}[data-theme=dark] .btn-secondary:hover{background:var(--accent-primary)!important;color:#fff!important;border-color:var(--accent-primary)!important}.back-button{background:#fff3!important;color:#fff!important;border:1px solid rgba(255,255,255,.3)!important}.back-button:hover{background:#ffffff4d!important}[data-theme=dark] .back-button{background:#ffffff26!important;color:#fff!important;border:1px solid rgba(255,255,255,.25)!important}[data-theme=dark] .back-button:hover{background:#ffffff40!important}.day-button{background:var(--card-bg)!important;color:var(--text-primary)!important;border:2px solid var(--border-color)!important}.day-button.active{background:linear-gradient(135deg,#4caf5026,#2196f326)!important;border-color:var(--accent-primary)!important}[data-theme=dark] .day-button{background:var(--bg-tertiary)!important;color:var(--text-primary)!important}[data-theme=dark] .day-button.active{background:linear-gradient(135deg,#66bb6a40,#42a5f540)!important;color:var(--text-primary)!important}.day-date{color:var(--text-secondary)!important}[data-theme=dark] .day-date{color:var(--text-tertiary)!important}.option-card{background:var(--card-bg)!important;border:2px solid var(--border-color)!important}.option-card .label{color:var(--text-primary)!important}[data-theme=dark] .option-card{background:var(--bg-tertiary)!important;border-color:var(--border-color)!important}[data-theme=dark] .option-card.selected{background:linear-gradient(135deg,#66bb6a33,#42a5f533)!important;border-color:var(--accent-primary)!important}.meal-card{background:var(--card-bg)!important;color:var(--text-primary)!important}[data-theme=dark] .meal-card{background:var(--bg-secondary)!important;color:var(--text-primary)!important}.meal-calories{color:#fff!important}.macro-item{color:var(--text-primary)!important}[data-theme=dark] .macro-item,.macro-label{color:var(--text-secondary)!important}[data-theme=dark] .macro-label{color:var(--text-tertiary)!important}.preparation-section p,.ingredient-quantity{color:var(--text-secondary)!important}[data-theme=dark] .preparation-section p,[data-theme=dark] .ingredient-quantity{color:var(--text-tertiary)!important}.conseil-jeune{color:var(--text-secondary)!important}[data-theme=dark] .conseil-jeune{color:var(--text-tertiary)!important}.form-group input{background:var(--input-bg)!important;color:var(--text-primary)!important;border-color:var(--input-border)!important}[data-theme=dark] .form-group input{background:var(--bg-tertiary)!important;color:var(--text-primary)!important;border-color:var(--border-color)!important}[data-theme=dark] .form-group input::placeholder{color:var(--text-tertiary)!important}.checkbox-label,.radio-label{background:var(--card-bg)!important;color:var(--text-primary)!important;border-color:var(--border-color)!important}[data-theme=dark] .checkbox-label,[data-theme=dark] .radio-label{background:var(--bg-tertiary)!important;color:var(--text-primary)!important}[data-theme=dark] .checkbox-label:has(input:checked),[data-theme=dark] .radio-label:has(input:checked){background:linear-gradient(135deg,#66bb6a33,#42a5f533)!important;border-color:var(--accent-primary)!important}.morphotype-card{background:var(--card-bg)!important;border-color:var(--border-color)!important}[data-theme=dark] .morphotype-card{background:var(--bg-tertiary)!important;color:var(--text-primary)!important}[data-theme=dark] .morphotype-card.selected{background:linear-gradient(135deg,#66bb6a33,#42a5f533)!important;border-color:var(--accent-primary)!important}.macros-section{background:var(--card-bg)!important}[data-theme=dark] .macros-section,.macro-card{background:var(--bg-secondary)!important}[data-theme=dark] .macro-card{background:var(--bg-tertiary)!important}.tips-section{background:var(--card-bg)!important}[data-theme=dark] .tips-section{background:var(--bg-secondary)!important}.days-navigation{background:var(--card-bg)!important}[data-theme=dark] .days-navigation{background:var(--bg-secondary)!important;box-shadow:0 2px 8px #00000080!important}.step{background:var(--card-bg)!important;color:var(--text-primary)!important}[data-theme=dark] .step{background:var(--bg-secondary)!important;color:var(--text-primary)!important}.quote{background:var(--card-bg)!important;color:var(--text-secondary)!important}[data-theme=dark] .quote{background:var(--bg-secondary)!important;color:var(--text-tertiary)!important;border-color:var(--border-color)!important}.help-text{color:var(--text-secondary)!important}[data-theme=dark] .help-text{background:linear-gradient(135deg,#66bb6a26,#42a5f526)!important;color:var(--text-tertiary)!important}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.questionnaire{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#667eea,#764ba2);position:relative}.questionnaire:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.1) 0%,transparent 50%);pointer-events:none}.header{background:#fff;padding:1rem 1rem .85rem;box-shadow:0 4px 12px #00000014;position:relative;z-index:10}.header h1{font-size:1.35rem;margin-bottom:1rem;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center;font-weight:800;letter-spacing:-.5px;line-height:1.2}.progress-bar{height:8px;background:#00000014;border-radius:8px;overflow:hidden;margin-bottom:.5rem;box-shadow:inset 0 2px 4px #0000000f}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));transition:width .4s cubic-bezier(.4,0,.2,1);box-shadow:0 0 12px #4caf5066;border-radius:8px}.step-indicator{text-align:center;color:#666;font-size:.75rem;font-weight:600;letter-spacing:.3px}.content{flex:1;padding:1rem .75rem;overflow-y:auto}.step{background:#fff;padding:1.5rem 1.25rem;border-radius:16px;box-shadow:0 8px 24px #0000001f;position:relative}.step h2{font-size:1.35rem;margin-bottom:.75rem;color:var(--text-primary);text-align:center;font-weight:700;letter-spacing:-.5px;line-height:1.3}.subtitle{text-align:center;color:#666;margin-bottom:1.25rem;font-size:.8rem;line-height:1.5}.subtitle-optional{text-align:center;color:#888;margin-bottom:1.25rem;font-size:.75rem;line-height:1.5;font-style:italic}.subtitle-optional:after{content:" (optionnel)";color:var(--accent-primary);font-weight:600}.help-text{text-align:center;background:linear-gradient(135deg,#4caf5014,#2196f314);padding:.6rem .85rem;border-radius:10px;font-size:.75rem;color:#555;margin:-.5rem 0 1rem;border-left:3px solid var(--accent-primary);font-weight:500;line-height:1.4}.options-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.65rem;margin-bottom:.85rem}.option-card{background:#fff;border:2px solid var(--border-color);border-radius:12px;padding:1.25rem 1rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;align-items:center;gap:.5rem;min-height:100px;position:relative;overflow:hidden}.option-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#4caf500d,#2196f30d);opacity:0;transition:opacity .3s ease}.option-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0000001f;border-color:var(--accent-primary)}.option-card:hover:before{opacity:1}.option-card.selected{border-color:var(--accent-primary);background:linear-gradient(135deg,#4caf5014,#2196f314);box-shadow:0 8px 20px #4caf5040}.option-card.selected:before{opacity:1}.option-card .icon{font-size:2.25rem;position:relative;z-index:1;transition:transform .3s ease}.option-card:hover .icon{transform:scale(1.08)}.option-card:active{transform:translateY(-1px) scale(.98)}.option-card .label{font-size:.85rem;font-weight:600;text-align:center;color:var(--text-primary);position:relative;line-height:1.3;z-index:1;letter-spacing:-.2px}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.625rem;font-weight:600;color:var(--text-primary);font-size:.95rem;letter-spacing:-.2px}.form-group input[type=number],.form-group input[type=text]{width:100%;padding:.875rem 1rem;border:2px solid var(--border-color);border-radius:12px;font-size:1rem;transition:all .3s ease;background:#fff;color:var(--text-primary);font-weight:500}.form-group input::placeholder{color:#999;font-weight:400}.form-group input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 4px #4caf501a;transform:translateY(-1px)}.form-group input:hover:not(:focus){border-color:#4caf5066}.radio-group{display:flex;gap:1rem}.radio-label{flex:1;display:flex;align-items:center;justify-content:center;gap:.625rem;padding:.875rem 1rem;border:3px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .3s ease;background:#fff}.radio-label.selected{border-color:var(--accent-primary);background:linear-gradient(135deg,#4caf5014,#2196f314);box-shadow:0 4px 12px #4caf5033}.radio-label:hover{border-color:var(--accent-primary);background:#4caf500d;transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.radio-label input[type=radio]{width:22px;height:22px;cursor:pointer;accent-color:var(--accent-primary);flex-shrink:0}.radio-label:has(input[type=radio]:checked){border-color:var(--accent-primary);background:linear-gradient(135deg,#4caf5014,#2196f314);box-shadow:0 4px 12px #4caf5033}.radio-label input[type=radio]:checked+span{color:var(--accent-primary);font-weight:700}.required{color:#e53e3e;font-weight:700;font-size:1.2rem;margin-left:.25rem}.field-note{font-size:.8rem;color:#666;margin:-.25rem 0 .75rem;font-style:italic;text-align:center}.dark-mode .field-note{color:#999}.checkbox-list{display:flex;flex-direction:column;gap:.75rem}.checkbox-label{display:flex;align-items:center;gap:.875rem;padding:1.125rem 1.25rem;border:2px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .3s ease;background:#fff}.checkbox-label:hover{border-color:var(--accent-primary);background:#4caf500d;transform:translate(4px)}.checkbox-label input[type=checkbox]{width:22px;height:22px;cursor:pointer;accent-color:var(--accent-primary);flex-shrink:0}.checkbox-label:has(input[type=checkbox]:checked){border-color:var(--accent-primary);background:linear-gradient(135deg,#4caf5014,#2196f314);box-shadow:0 2px 8px #4caf5026}.checkbox-label input[type=checkbox]:checked+span{color:var(--accent-primary);font-weight:700}.error{color:var(--danger);font-size:.875rem;margin-top:.5rem}.navigation{background:#fff;padding:1rem 1.5rem;display:flex;gap:1rem;box-shadow:0 -2px 8px #0000001a}.btn-primary,.btn-secondary{flex:1;padding:1rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;min-height:48px}.btn-primary{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;box-shadow:0 2px 8px #4caf5033}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #4caf5059}.btn-primary:active{transform:translateY(0);box-shadow:0 2px 8px #4caf5033}.btn-secondary{background:#fff;color:var(--text-primary);border:2px solid var(--border-color)}.btn-secondary:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.quote{background:#fffffffa;padding:1.25rem 1.75rem;margin:1rem 1.5rem 0;border-radius:16px;text-align:center;font-style:italic;color:#555;box-shadow:0 4px 16px #0000001f;border:2px solid rgba(255,255,255,.5);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.quote p{font-size:1.05rem;line-height:1.6;margin:0}.morphotype-grid{display:grid;gap:1rem;margin-bottom:1rem}.morphotype-card{background:#fff;border:3px solid var(--border-color);border-radius:16px;padding:1.5rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:flex-start;gap:1rem;text-align:left;position:relative;overflow:hidden}.morphotype-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,var(--accent-primary),var(--accent-secondary));opacity:0;transition:opacity .3s ease}.morphotype-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:var(--accent-primary)}.morphotype-card:hover:before{opacity:1}.morphotype-card.selected{border-color:var(--accent-primary);background:linear-gradient(135deg,#4caf5014,#2196f314);box-shadow:0 8px 24px #4caf5033}.morphotype-card.selected:before{opacity:1}.morphotype-card:active{transform:translateY(-2px) scale(.98)}.morphotype-icon{font-size:3rem;flex-shrink:0;line-height:1;padding:.5rem;background:linear-gradient(135deg,#4caf501a,#2196f31a);border-radius:12px;display:flex;align-items:center;justify-content:center;width:70px;height:70px}.morphotype-content{flex:1;display:flex;flex-direction:column;gap:.5rem}.morphotype-title{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.25rem}.morphotype-id{font-size:.85rem;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));padding:.25rem .6rem;border-radius:6px;letter-spacing:.5px}.morphotype-name{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.morphotype-description{font-size:.95rem;color:var(--text-primary);font-weight:500;margin:0}.morphotype-traits{font-size:.85rem;color:#666;line-height:1.4;margin:0}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(.95)}}.option-card.selected,.morphotype-card.selected{animation:pulse .3s ease-in-out}.step{transition:opacity .2s ease-in-out}@media(max-width:480px){.options-grid{grid-template-columns:1fr}.option-card{flex-direction:row;justify-content:flex-start;min-height:auto;padding:1rem}.option-card .icon{font-size:2rem}.radio-group{flex-direction:column}.morphotype-card{padding:1.25rem}.morphotype-icon{font-size:2.5rem;width:60px;height:60px}.morphotype-name{font-size:1rem}}.shopping-list-modal{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .3s ease}.shopping-list-container{background:#fff;border-radius:20px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease;position:relative}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.close-button{position:absolute;top:15px;right:15px;background:#ff4757;color:#fff;border:none;width:35px;height:35px;border-radius:50%;font-size:20px;cursor:pointer;transition:all .3s ease;z-index:10}.close-button:hover{background:#ff3838;transform:rotate(90deg)}.shopping-list-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:30px;text-align:center;border-radius:20px 20px 0 0}.shopping-list-header h2{margin:0 0 10px;font-size:28px;font-weight:700}.shopping-list-subtitle{margin:0 0 20px;opacity:.9;font-size:16px}.shopping-list-progress{margin-top:20px}.progress-text{display:block;font-size:14px;margin-bottom:8px;opacity:.95}.progress-bar{background:#ffffff4d;height:8px;border-radius:10px;overflow:hidden}.progress-fill{background:#2ecc71;height:100%;transition:width .3s ease;border-radius:10px}.shopping-list-actions{display:flex;gap:10px;padding:20px;background:#f8f9fa;border-bottom:1px solid #e9ecef}.action-btn{flex:1;padding:12px 16px;border:none;border-radius:10px;background:#fff;color:#495057;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 5px #0000000d}.action-btn:hover{transform:translateY(-2px);box-shadow:0 4px 10px #0000001a;background:#667eea;color:#fff}.shopping-list-content{padding:20px}.shopping-category{margin-bottom:20px;border-radius:12px;overflow:hidden;border:1px solid #e9ecef;background:#fff}.category-header{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:15px 20px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:all .3s ease}.category-header:hover{background:linear-gradient(135deg,#e9ecef,#b8c5d6)}.category-title{display:flex;align-items:center;gap:10px;font-weight:600;font-size:16px;color:#2d3436}.category-icon{font-size:22px}.category-count{font-size:14px;color:#636e72;font-weight:500}.category-toggle{font-size:12px;color:#636e72;transition:transform .3s ease}.category-items{padding:10px}.shopping-item{display:flex;align-items:center;gap:12px;padding:12px 15px;border-radius:8px;cursor:pointer;transition:all .2s ease;margin-bottom:5px}.shopping-item:hover{background:#f8f9fa}.shopping-item.checked{opacity:.5;text-decoration:line-through}.item-checkbox{width:20px;height:20px;cursor:pointer;accent-color:#2ecc71}.item-name{flex:1;font-size:15px;color:#2d3436;font-weight:500}.item-quantity{font-size:14px;color:#636e72;font-weight:600;background:#f1f3f5;padding:4px 12px;border-radius:20px}.shopping-list-footer{background:#f8f9fa;padding:20px;text-align:center;border-top:1px solid #e9ecef}.footer-note{margin:0 0 15px;color:#636e72;font-size:14px}.btn-close-footer{padding:12px 30px;border:none;border-radius:10px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-close-footer:hover{transform:translateY(-2px);box-shadow:0 4px 15px #667eea66}@media print{.shopping-list-modal{position:static;background:#fff}.shopping-list-container{max-height:none;box-shadow:none}.close-button,.shopping-list-actions,.btn-close-footer{display:none!important}.shopping-item:hover{background:none}.item-checkbox{print-color-adjust:exact;-webkit-print-color-adjust:exact}}@media(max-width:640px){.shopping-list-container{max-width:100%;max-height:100vh;border-radius:0}.shopping-list-header{border-radius:0;padding:25px 20px}.shopping-list-header h2{font-size:24px}.shopping-list-actions{flex-direction:column}.action-btn{width:100%}}.weekly-menu{min-height:100vh;background:var(--bg-primary);padding-bottom:2rem}.loading-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.error-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;padding:2rem;max-width:600px;margin:0 auto;text-align:center}.error-container h2{color:var(--text-primary);margin:0;font-size:1.5rem}.error-message{color:var(--error-color, #d32f2f);font-weight:600;background:var(--error-bg, rgba(211, 47, 47, .1));padding:1rem;border-radius:8px;border-left:4px solid var(--error-color, #d32f2f)}.error-message-detailed{text-align:left;background:var(--bg-secondary, #f9f9f9);padding:1.5rem;border-radius:12px;width:100%;max-width:800px;max-height:60vh;overflow-y:auto;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:.9rem;line-height:1.6;box-shadow:0 2px 8px #0000001a}.error-line{margin:.25rem 0;color:var(--text-secondary, #555);white-space:pre-wrap;word-wrap:break-word}.error-section-header{margin:1rem 0 .5rem;color:var(--text-primary, #222);font-weight:700;font-size:1rem;border-bottom:2px solid var(--accent-primary, #4CAF50);padding-bottom:.25rem;white-space:pre-wrap;word-wrap:break-word}.error-actions{display:flex;gap:1rem;margin-top:1rem;flex-wrap:wrap;justify-content:center}.btn-practitioner{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;transition:all .3s ease;box-shadow:0 4px 12px #667eea4d}.btn-practitioner:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.dark-mode .error-message-detailed{background:var(--bg-secondary, #2a2a2a);color:var(--text-primary, #e0e0e0)}.dark-mode .error-line{color:var(--text-secondary, #b0b0b0)}.dark-mode .error-section-header{color:var(--text-primary, #f0f0f0);border-bottom-color:var(--accent-primary, #66BB6A)}.error-details{text-align:left;background:var(--bg-secondary);padding:1.5rem;border-radius:8px;width:100%}.error-details p{margin:.5rem 0;color:var(--text-secondary)}.error-hint{margin-top:1rem!important;padding:1rem;background:var(--accent-light, rgba(99, 102, 241, .1));border-radius:6px;border-left:3px solid var(--accent-primary)}.error-hint strong{color:var(--accent-primary)}.error-hint a{color:var(--accent-primary);text-decoration:none;font-weight:600}.error-hint a:hover{text-decoration:underline}.file-list{list-style:none;padding:0;margin:1rem 0}.file-list li{padding:.5rem;background:var(--bg-primary);margin:.5rem 0;border-radius:6px;font-family:monospace;color:var(--text-primary)}.btn-back{background:var(--accent-primary);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s ease;margin-top:1rem}.btn-back:hover{background:var(--accent-secondary);transform:translateY(-2px);box-shadow:0 4px 12px #0003}.spinner{width:50px;height:50px;border:4px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}.menu-header{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;padding:1.5rem;position:relative}.back-button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.5rem 1rem;border-radius:8px;cursor:pointer;margin-bottom:1rem;font-size:.9rem;transition:all .3s ease}.back-button:hover{background:#ffffff4d}.menu-header h1{font-size:1.5rem;margin-bottom:1rem}.profile-summary{display:flex;flex-direction:column;gap:.75rem;font-size:.9rem;background:#ffffff1a;padding:1rem;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.profile-summary p{margin:0;background:#ffffff26;padding:.5rem 1rem;border-radius:8px;display:flex;justify-content:space-between;align-items:center}.profile-summary p strong{font-weight:600;margin-right:.5rem}.profile-summary .macro-info{background:#ffffff40;border:1px solid rgba(255,255,255,.3);font-weight:500}.days-navigation{display:flex;overflow-x:auto;padding:1rem;gap:.5rem;background:#fff;box-shadow:0 2px 8px #0000001a;-webkit-overflow-scrolling:touch}.day-button{min-width:70px;padding:.75rem .5rem;border:2px solid var(--border-color);border-radius:12px;background:#fff;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.25rem;transition:all .3s ease;position:relative}.day-button:hover{border-color:var(--accent-primary);transform:translateY(-2px)}.day-button.active{border-color:var(--accent-primary);background:linear-gradient(135deg,#4caf501a,#2196f31a);box-shadow:0 4px 12px #4caf5033}.day-button.jeune-day{border-color:var(--accent-tertiary)}.day-name{font-weight:600;font-size:.9rem}.day-date{font-size:.8rem;color:#666}.jeune-badge{position:absolute;top:-5px;right:-5px;font-size:1rem}.day-menu{padding:1.5rem}.day-menu h2{text-align:center;color:var(--text-primary);margin-bottom:1.5rem;font-size:1.3rem}.jeune-alert{background:linear-gradient(135deg,#ff98001a,#ffc1071a);border:2px solid var(--accent-tertiary);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;text-align:center}.jeune-alert h3{color:var(--accent-tertiary);margin-bottom:.5rem}.conseil-jeune{margin-top:1rem;font-style:italic;color:#666}.meals-container{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.meal-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:all .3s ease}.meal-card:hover{box-shadow:0 4px 16px #00000026}.meal-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:.5rem;gap:.5rem}.meal-header>div{display:flex;flex-direction:column;gap:.25rem;flex:1}.meal-header h4{font-size:1.2rem;color:var(--text-primary);margin:0}.meal-calories{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.9rem;font-weight:600;white-space:nowrap;display:inline-block;width:fit-content}.btn-regenerate{background:linear-gradient(135deg,#9c27b0,#e91e63);border:none;color:#fff;padding:.5rem .9rem;border-radius:20px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.4rem;flex-shrink:0;box-shadow:0 2px 8px #9c27b04d;white-space:nowrap}.btn-regenerate:hover:not(:disabled){transform:translateY(-2px) scale(1.05);box-shadow:0 4px 12px #9c27b080}.btn-regenerate:active:not(:disabled){transform:translateY(0) scale(.98)}.btn-regenerate:disabled{opacity:.6;cursor:not-allowed;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.meal-moment{color:#666;font-size:.9rem;margin-bottom:.75rem}.meal-macros{display:flex;gap:1rem;margin-bottom:.75rem;padding:.5rem;background:#4caf500d;border-radius:8px;flex-wrap:wrap}.macro-item{font-size:.85rem;font-weight:600;color:#555;display:flex;align-items:center;gap:.25rem}.meal-note{background:#4caf501a;padding:.75rem;border-radius:8px;border-left:4px solid var(--accent-primary);margin-bottom:.75rem;font-size:.9rem;font-style:italic}.toggle-details{background:none;border:none;color:var(--accent-primary);cursor:pointer;font-weight:600;padding:.5rem 0;font-size:.9rem;width:100%;text-align:left;transition:color .3s ease}.toggle-details:hover{color:var(--accent-secondary)}.meal-details{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.ingredients-section,.preparation-section{margin-bottom:1rem}.ingredients-section h5,.preparation-section h5{color:var(--accent-primary);margin-bottom:.5rem}.ingredients-section ul{list-style:none;padding:0}.ingredients-section li{padding:.5rem 0 .5rem 1.5rem;position:relative;line-height:1.6}.ingredient-name{font-weight:600;color:var(--text-primary)}.ingredient-quantity{color:#666;font-weight:500;font-size:.95em}.ingredients-section li:before{content:"✓";position:absolute;left:0;color:var(--accent-primary);font-weight:700}.preparation-section p{line-height:1.6;color:#555}.macros-section{padding:1.5rem;background:#fff;margin:0 1.5rem 1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.macros-section h3{text-align:center;color:var(--text-primary);margin-bottom:1rem}.macros-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.macro-card{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:1rem;background:var(--bg-primary);border-radius:8px}.macro-icon{font-size:2rem}.macro-label{font-size:.8rem;color:#666}.macro-value{font-size:1.2rem;font-weight:600;color:var(--text-primary)}.macro-percent{font-size:.8rem;color:var(--accent-primary);font-weight:600}.tips-section{padding:1.5rem;background:#fff;margin:0 1.5rem 1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.tips-section h3{text-align:center;color:var(--text-primary);margin-bottom:1rem}.tips-list{display:flex;flex-direction:column;gap:.75rem}.tip-card{padding:1rem;background:linear-gradient(135deg,#4caf500d,#2196f30d);border-left:4px solid var(--accent-primary);border-radius:8px;font-size:.9rem}.actions-section{display:flex;gap:1rem;padding:0 1.5rem}.btn-action{flex:1;padding:1rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-shopping{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-print{background:var(--accent-secondary);color:#fff}.btn-share{background:var(--accent-primary);color:#fff}.btn-action:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}@media print{.days-navigation,.actions-section,.back-button{display:none}.meal-card{page-break-inside:avoid}}@media(max-width:480px){.macros-grid{grid-template-columns:1fr}.profile-summary,.meal-header{flex-direction:column;gap:.5rem}.meal-calories{align-self:flex-start}}.regenerate-container{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.proposition-counter{background:linear-gradient(135deg,#9c27b01a,#e91e631a);border:2px solid #9c27b0;color:#9c27b0;padding:.25rem .6rem;border-radius:15px;font-size:.75rem;font-weight:700;white-space:nowrap;animation:fadeIn .3s ease}[data-theme=dark] .proposition-counter{background:linear-gradient(135deg,#9c27b033,#e91e6333);border-color:#ba68c8;color:#ba68c8}.spinner-small{display:inline-block;width:12px;height:12px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin-right:.3rem}.meal-card-fade-out{animation:fadeOut .3s ease forwards}.meal-card-fade-in{animation:fadeIn .3s ease forwards}@keyframes fadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}[data-theme=dark] .btn-regenerate{background:linear-gradient(135deg,#ba68c8,#f06292);box-shadow:0 2px 8px #ba68c84d}[data-theme=dark] .btn-regenerate:hover:not(:disabled){box-shadow:0 4px 12px #ba68c880}.meals-container{position:relative}@media(max-width:480px){.regenerate-container{flex-direction:column;align-items:flex-start;gap:.5rem;width:100%}.btn-regenerate{width:100%;justify-content:center}.proposition-counter{align-self:flex-start}}.meal-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.btn-favorite{background:transparent;border:2px solid var(--border-color);font-size:1.5rem;width:44px;height:44px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;flex-shrink:0}.btn-favorite:hover{transform:scale(1.1);border-color:var(--accent-primary)}.btn-favorite.is-favorite{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);border-color:#ff6b6b;animation:heartBeat .5s ease}@keyframes heartBeat{0%,to{transform:scale(1)}25%{transform:scale(1.2)}50%{transform:scale(.95)}75%{transform:scale(1.1)}}.favorite-toast{position:absolute;top:-2rem;left:50%;transform:translate(-50%);background:var(--success);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.85rem;font-weight:600;box-shadow:0 4px 12px #0003;animation:slideDown .3s ease;z-index:10}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}[data-theme=dark] .btn-favorite{border-color:var(--border-color)}[data-theme=dark] .btn-favorite:hover{border-color:var(--accent-primary)}@media(max-width:480px){.meal-header{flex-wrap:wrap}.meal-actions{width:100%;justify-content:space-between;margin-top:.5rem}.btn-favorite{order:-1}}.user-manager{padding:1rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-card.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.stat-icon{font-size:2rem;opacity:.9}.stat-content{flex:1}.stat-value{font-size:2rem;font-weight:700;line-height:1;margin-bottom:.25rem}.stat-label{font-size:.875rem;opacity:.8}.user-controls{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap;align-items:center}.search-box{flex:1;min-width:250px;position:relative}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);font-size:1.2rem;opacity:.5}.search-box input{width:100%;padding:.75rem 1rem .75rem 3rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s}.search-box input:focus{outline:none;border-color:#667eea}.filter-group{display:flex;gap:.5rem}.filter-group select{padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:.9rem;background:#fff;cursor:pointer;transition:border-color .2s}.filter-group select:focus{outline:none;border-color:#667eea}.btn-refresh{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-refresh:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.users-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.users-table{width:100%;border-collapse:collapse}.users-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.users-table th{padding:1rem;text-align:left;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.users-table tbody tr{border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background-color .2s}.users-table tbody tr:hover{background-color:#f8f9ff}.users-table td{padding:1rem;font-size:.9rem}.users-table td.centered{text-align:center}.users-table td.actions{text-align:right}.no-data{text-align:center;padding:3rem 1rem;color:#999;font-style:italic}.user-info{display:flex;flex-direction:column;gap:.25rem}.user-name{font-weight:600;color:#333}.user-email{font-size:.8rem;color:#666}.status-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-badge.active{background:#e8f5e9;color:#2e7d32}.status-badge.inactive{background:#ffebee;color:#c62828}.objectif-badge{display:inline-block;padding:.25rem .75rem;background:#f0f0f0;border-radius:12px;font-size:.85rem}.badge{display:inline-block;padding:.25rem .5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;font-size:.85rem;font-weight:600;min-width:2rem;text-align:center}.profile-summary{display:flex;gap:.5rem;flex-wrap:wrap;font-size:.8rem;color:#666}.btn-icon{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:.25rem .5rem;transition:transform .2s}.btn-icon:hover{transform:scale(1.2)}.btn-icon.danger:hover{filter:brightness(1.2)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.user-detail-modal{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0003;max-width:800px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.modal-header h2{margin:0;font-size:1.5rem}.btn-close{background:#fff3;border:none;color:#fff;font-size:1.5rem;width:2rem;height:2rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.btn-close:hover{background:#ffffff4d}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.detail-section{margin-bottom:2rem}.detail-section h3{margin:0 0 1rem;font-size:1.2rem;color:#333;border-bottom:2px solid #f0f0f0;padding-bottom:.5rem}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.detail-item{padding:.75rem;background:#f8f9ff;border-radius:8px;font-size:.9rem}.detail-item.full-width{grid-column:1 / -1}.detail-item strong{display:block;margin-bottom:.25rem;color:#666;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}.detail-item code{background:#e0e0e0;padding:.25rem .5rem;border-radius:4px;font-size:.85rem;font-family:Courier New,monospace}.stats-row{display:flex;gap:1rem}.stat-box{flex:1;text-align:center;padding:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px}.stat-number{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.stat-text{font-size:.9rem;opacity:.9}.login-history{max-height:300px;overflow-y:auto}.history-list{display:flex;flex-direction:column;gap:.5rem}.history-item{display:flex;gap:1rem;align-items:center;padding:.75rem;background:#f8f9ff;border-radius:8px;font-size:.85rem}.history-date{font-weight:600;color:#333;min-width:140px}.history-method{padding:.25rem .75rem;background:#fff;border-radius:12px;font-size:.75rem}.history-ip{color:#666;font-family:Courier New,monospace;font-size:.8rem}.history-more{text-align:center;padding:1rem;color:#666;font-style:italic;font-size:.85rem}.modal-footer{padding:1rem 1.5rem;background:#f8f9fa;border-top:1px solid #e0e0e0;display:flex;gap:1rem;justify-content:flex-end}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn:hover{transform:translateY(-2px)}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{box-shadow:0 4px 12px #667eea66}.btn-danger{background:linear-gradient(135deg,#f56565,#c53030);color:#fff}.btn-danger:hover{box-shadow:0 4px 12px #f5656566}.btn-secondary{background:#e0e0e0;color:#333}.btn-secondary:hover{background:#d0d0d0}@media(max-width:768px){.user-controls{flex-direction:column;align-items:stretch}.search-box{min-width:100%}.filter-group{flex-direction:column}.filter-group select{width:100%}.users-table-container{overflow-x:auto}.users-table{min-width:900px}.detail-grid{grid-template-columns:1fr}.stats-row,.modal-footer{flex-direction:column}.modal-footer .btn{width:100%}}.admin-login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.login-container{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:3rem;max-width:400px;width:100%;animation:slideUp .5s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:2rem;margin-bottom:.5rem;color:#333}.login-header p{color:#666;font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:1rem}.form-group label{font-weight:600;color:#333;font-size:.9rem}.form-group input{padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#667eea}.error-message{background:#fee;color:#c33;padding:.75rem;border-radius:8px;font-size:.9rem;text-align:center}.btn-login{padding:.875rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s}.btn-login:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.btn-back{padding:.75rem;background:#f5f5f5;color:#666;border:none;border-radius:8px;cursor:pointer;transition:background .2s}.btn-back:hover{background:#e0e0e0}.login-hint{text-align:center;color:#999;font-size:.85rem;margin-top:1rem;padding:.5rem;background:#f9f9f9;border-radius:8px}.admin-portal{display:flex;min-height:100vh;background:#f5f7fa}.admin-sidebar{width:260px;background:linear-gradient(180deg,#2c3e50,#34495e);color:#fff;display:flex;flex-direction:column;box-shadow:4px 0 20px #0000001a}.sidebar-header{padding:2rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-header h2{margin:0 0 .25rem;font-size:1.5rem}.sidebar-header p{margin:0;opacity:.7;font-size:.85rem}.sidebar-nav{flex:1;padding:1rem 0}.nav-item{width:100%;display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:none;border:none;border-left:4px solid transparent;color:#fffc;cursor:pointer;transition:all .3s;font-size:1rem}.nav-item:hover{background:#ffffff1a;color:#fff}.nav-item.active{background:#ffffff26;border-left-color:#3498db;color:#fff;font-weight:600}.nav-icon{font-size:1.25rem}.nav-label{flex:1;text-align:left}.sidebar-footer{padding:1rem;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:.5rem}.btn-logout,.btn-app{padding:.75rem;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s}.btn-logout{background:#e74c3c33;color:#e74c3c}.btn-logout:hover{background:#e74c3c4d}.btn-app{background:#ffffff1a;color:#fff}.btn-app:hover{background:#fff3}.admin-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.content-header{background:#fff;padding:1.5rem 2rem;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #0000000d}.content-header h1{margin:0;font-size:1.75rem;color:#2c3e50}.header-actions{display:flex;gap:1rem;align-items:center}.user-badge{padding:.5rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:20px;font-size:.9rem;font-weight:600}.content-body{flex:1;overflow-y:auto;padding:2rem}.admin-dashboard{max-width:1400px;margin:0 auto}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 12px #00000014;display:flex;align-items:center;gap:1rem;transition:transform .2s}.stat-card:hover{transform:translateY(-4px);box-shadow:0 4px 20px #0000001f}.stat-icon{font-size:2.5rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;border-radius:12px}.stat-card.primary .stat-icon{background:linear-gradient(135deg,#667eea,#764ba2)}.stat-card.success .stat-icon{background:linear-gradient(135deg,#56ab2f,#a8e063)}.stat-card.info .stat-icon{background:linear-gradient(135deg,#3498db,#2980b9)}.stat-card.warning .stat-icon{background:linear-gradient(135deg,#f39c12,#f1c40f)}.stat-content h3{margin:0;font-size:2rem;color:#2c3e50}.stat-content p{margin:.25rem 0 0;color:#7f8c8d;font-size:.9rem}.info-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.info-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 12px #00000014}.info-card h3{margin:0 0 1rem;color:#2c3e50;font-size:1.1rem}.info-grid{display:flex;flex-direction:column;gap:.75rem}.info-item{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #f0f0f0}.info-label{color:#7f8c8d;font-size:.9rem}.info-value{font-weight:600;color:#2c3e50;font-size:.9rem}.quick-actions{display:flex;flex-direction:column;gap:.75rem}.action-btn{padding:.75rem;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s;font-size:.9rem;text-align:left}.action-btn:hover{background:#e9ecef;border-color:#667eea;transform:translate(4px)}.alerts-section{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 12px #00000014;margin-bottom:2rem}.alerts-section h3{margin:0 0 1rem;color:#2c3e50}.alert-list{display:flex;flex-direction:column;gap:1rem}.alert{display:flex;gap:1rem;padding:1rem;border-radius:8px;border-left:4px solid}.alert.info{background:#e3f2fd;border-left-color:#2196f3}.alert.warning{background:#fff3e0;border-left-color:#ff9800}.alert.danger{background:#ffebee;border-left-color:#f44336}.alert-icon{font-size:1.5rem}.alert-content strong{display:block;margin-bottom:.25rem;color:#2c3e50}.alert-content p{margin:0;color:#7f8c8d;font-size:.9rem}.version-info{text-align:center;padding:1rem;color:#7f8c8d;font-size:.85rem}.version-info p{margin:.25rem 0}.recipe-manager{max-width:1200px;margin:0 auto}.manager-header{display:flex;gap:1rem;margin-bottom:2rem;align-items:center}.search-bar{flex:1}.search-bar input{width:100%;padding:.875rem 1rem;border:2px solid #e0e0e0;border-radius:10px;font-size:1rem;transition:border-color .2s}.search-bar input:focus{outline:none;border-color:#667eea}.btn-add{padding:.875rem 1.5rem;background:linear-gradient(135deg,#56ab2f,#a8e063);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;white-space:nowrap;transition:transform .2s}.btn-add:hover{transform:translateY(-2px);box-shadow:0 4px 12px #56ab2f66}.category-tabs{display:flex;gap:.5rem;margin-bottom:2rem;flex-wrap:wrap}.tab{padding:.75rem 1.25rem;background:#fff;border:2px solid #e0e0e0;border-radius:10px;cursor:pointer;transition:all .2s;font-size:.9rem}.tab:hover{border-color:#667eea;background:#f8f9fa}.tab.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea;font-weight:600}.recipes-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.recipe-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 12px #00000014;display:flex;justify-content:space-between;align-items:center;transition:transform .2s}.recipe-card:hover{transform:translate(4px);box-shadow:0 4px 16px #0000001f}.recipe-info h4{margin:0 0 .5rem;color:#2c3e50;font-size:1.1rem}.recipe-meta{display:flex;gap:1rem;align-items:center}.badge{padding:.25rem .75rem;background:#e3f2fd;color:#1976d2;border-radius:12px;font-size:.85rem;font-weight:600}.ingredient-count{color:#7f8c8d;font-size:.9rem}.recipe-actions{display:flex;gap:.5rem}.btn-icon{width:36px;height:36px;border:none;background:#f8f9fa;border-radius:8px;cursor:pointer;font-size:1rem;transition:all .2s}.btn-icon:hover{background:#e9ecef;transform:scale(1.1)}.btn-icon.danger:hover{background:#ffebee;color:#f44336}.recipe-stats{display:flex;gap:2rem;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;margin-bottom:2rem}.stat-box{flex:1;text-align:center}.stat-box strong{display:block;font-size:2rem;color:#2c3e50;margin-bottom:.25rem}.stat-box span{color:#7f8c8d;font-size:.9rem}.dev-note{background:#fff9e6;border-left:4px solid #ffc107;padding:1.5rem;border-radius:8px}.dev-note p{margin:.5rem 0;color:#666;font-size:.9rem}.dev-note code{background:#0000000d;padding:.125rem .375rem;border-radius:4px;font-family:Courier New,monospace;font-size:.85rem}.empty-state{text-align:center;padding:3rem;color:#7f8c8d}.mappings-viewer{max-width:1400px;margin:0 auto}.viewer-header{margin-bottom:2rem}.filter-buttons{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap}.filter-btn{padding:.5rem 1rem;background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s;font-size:.85rem}.filter-btn:hover{border-color:#667eea}.filter-btn.active{background:#667eea;color:#fff;border-color:#667eea;font-weight:600}.mappings-stats{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.stat-badge{background:#fff;padding:.75rem 1.25rem;border-radius:10px;box-shadow:0 2px 8px #00000014;display:flex;gap:.5rem;align-items:center}.badge-label{color:#7f8c8d;font-size:.9rem}.badge-value{font-weight:700;color:#2c3e50;font-size:1.1rem}.mappings-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;overflow:hidden;margin-bottom:2rem}.mappings-table{width:100%;border-collapse:collapse}.mappings-table thead{background:#f8f9fa}.mappings-table th{padding:1rem;text-align:left;font-weight:600;color:#2c3e50;border-bottom:2px solid #e0e0e0;font-size:.9rem}.mappings-table td{padding:1rem;border-bottom:1px solid #f0f0f0;font-size:.9rem}.mappings-table tbody tr:hover{background:#f8f9fa}.ingredient-cell{font-weight:500;color:#2c3e50}.code-cell code{background:#f8f9fa;padding:.25rem .5rem;border-radius:4px;font-family:Courier New,monospace;color:#667eea;font-weight:600}.category-badge{padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:600;display:inline-block}.category-badge.herbs{background:#e8f5e9;color:#2e7d32}.category-badge.vegetables{background:#fff3e0;color:#f57c00}.category-badge.legumes{background:#fce4ec;color:#c2185b}.category-badge.cereals{background:#fff9c4;color:#f57f17}.category-badge.fruits{background:#ffebee;color:#c62828}.category-badge.meat{background:#f3e5f5;color:#7b1fa2}.category-badge.fish{background:#e1f5fe;color:#0277bd}.category-badge.dairy{background:#e0f2f1;color:#00695c}.category-badge.other{background:#f5f5f5;color:#616161}.actions-cell{display:flex;gap:.5rem}.empty-row{text-align:center;padding:3rem!important;color:#7f8c8d}.export-section{display:flex;gap:1rem;justify-content:center}.btn-export{padding:.875rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:transform .2s}.settings-panel{max-width:900px;margin:0 auto}.settings-section{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 12px #00000014;margin-bottom:2rem}.settings-section h3{margin:0 0 1.5rem;color:#2c3e50;font-size:1.25rem}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 0;border-bottom:1px solid #f0f0f0}.setting-item:last-child{border-bottom:none}.setting-label{flex:1}.setting-label label{display:block;font-weight:600;color:#2c3e50;margin-bottom:.25rem}.setting-description{display:block;color:#7f8c8d;font-size:.85rem}.setting-input,.setting-select{padding:.5rem .75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:.9rem;min-width:120px}.setting-input:focus,.setting-select:focus{outline:none;border-color:#667eea}.toggle-switch{position:relative;display:inline-block;width:56px;height:30px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.3s;border-radius:30px}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:4px;bottom:4px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background:linear-gradient(135deg,#56ab2f,#a8e063)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(26px)}.db-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.db-card{background:#f8f9fa;padding:1.5rem;border-radius:10px;border:2px solid #e0e0e0}.db-card h4{margin:0 0 .5rem;color:#2c3e50}.db-desc{color:#7f8c8d;font-size:.85rem;margin-bottom:1rem}.db-stats{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;font-size:.85rem;color:#666}.btn-sm{padding:.5rem 1rem;background:#fff;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s}.btn-sm:hover{background:#667eea;color:#fff;border-color:#667eea}.settings-actions{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem}.btn-primary{padding:.875rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:transform .2s}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-secondary{padding:.875rem 2rem;background:#f8f9fa;color:#666;border:2px solid #e0e0e0;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#e9ecef;border-color:#667eea}.system-info{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 12px #00000014}.system-info h3{margin:0 0 1rem;color:#2c3e50}.info-row{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid #f0f0f0}.info-row:last-child{border-bottom:none}.info-row span:first-child{color:#7f8c8d;font-size:.9rem}.info-row span:last-child{font-weight:600;color:#2c3e50;font-size:.9rem}@media(max-width:768px){.admin-portal{flex-direction:column}.admin-sidebar{width:100%;height:auto}.sidebar-nav{display:flex;overflow-x:auto}.nav-item{flex-direction:column;gap:.25rem;padding:.75rem;border-left:none;border-bottom:4px solid transparent}.nav-item.active{border-left:none;border-bottom-color:#3498db}.content-body{padding:1rem}.stats-grid{grid-template-columns:1fr}.manager-header,.export-section{flex-direction:column}}.practitioner-portal{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:2rem 1rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.practitioner-portal .loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:400px;gap:1rem}.practitioner-portal .spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #4CAF50;border-radius:50%;animation:spin 1s linear infinite}.practitioner-portal .loading-container p{font-size:1.1rem;color:#666}.dark-mode .practitioner-portal .loading-container p{color:#ccc}.dark-mode .practitioner-portal{background:linear-gradient(135deg,#1a1a2e,#16213e)}.practitioner-header{max-width:1200px;margin:0 auto 2rem;display:flex;justify-content:space-between;align-items:center;background:#fff;padding:1.5rem 2rem;border-radius:16px;box-shadow:0 4px 20px #00000014}.dark-mode .practitioner-header{background:#1e1e30;box-shadow:0 4px 20px #0000004d}.practitioner-header h1{font-size:1.8rem;color:#2d3748;margin:0;display:flex;align-items:center;gap:.5rem}.dark-mode .practitioner-header h1{color:#e2e8f0}.header-actions{display:flex;gap:1rem}.btn-back{padding:.75rem 1.5rem;background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;font-size:.95rem;font-weight:500;color:#4a5568;cursor:pointer;transition:all .2s}.btn-back:hover{background:#edf2f7;border-color:#cbd5e0}.dark-mode .btn-back{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.dark-mode .btn-back:hover{background:#374151}.practitioner-container{max-width:1200px;margin:0 auto}.storage-stats{background:#fff;padding:1.5rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 2px 12px #0000000f}.dark-mode .storage-stats{background:#1e1e30}.storage-stats h3{margin:0 0 1rem;color:#2d3748;font-size:1.1rem}.dark-mode .storage-stats h3{color:#e2e8f0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.stat-item{text-align:center;padding:1rem;background:#f7fafc;border-radius:8px}.dark-mode .stat-item{background:#2d3748}.stat-value{font-size:1.8rem;font-weight:700;color:#f093fb;display:block;margin-bottom:.25rem}.stat-label{font-size:.85rem;color:#718096}.dark-mode .stat-label{color:#a0aec0}.storage-bar{margin-top:1rem;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}.dark-mode .storage-bar{background:#4a5568}.storage-fill{height:100%;background:linear-gradient(90deg,#f093fb,#f5576c);transition:width .3s ease}.persistence-info{margin-top:1rem;padding:1rem 1.25rem;background:#e6f7ff;border-left:4px solid #1890ff;border-radius:8px;display:flex;align-items:center;gap:1rem}.dark-mode .persistence-info{background:#1890ff26;border-color:#40a9ff}.persistence-icon{font-size:1.5rem;flex-shrink:0}.persistence-text{font-size:.9rem;color:#0050b3;line-height:1.5}.dark-mode .persistence-text{color:#91d5ff}.persistence-text strong{font-weight:600}.activation-section{background:#fff;padding:1.5rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 2px 12px #0000000f;border:3px solid transparent;transition:all .3s ease}.activation-section.active{border-color:#48bb78;background:#f0fff4}.activation-section.inactive{border-color:#fbd38d;background:#fffaf0}.dark-mode .activation-section{background:#1e1e30;box-shadow:0 2px 12px #0000004d}.dark-mode .activation-section.active{border-color:#48bb78;background:#48bb781a}.dark-mode .activation-section.inactive{border-color:#ed8936;background:#ed89361a}.activation-header{display:flex;justify-content:space-between;align-items:center;gap:1.5rem}.activation-info h3{margin:0 0 .5rem;font-size:1.3rem;color:#2d3748}.dark-mode .activation-info h3{color:#e2e8f0}.activation-info p{margin:0;color:#718096;font-size:.95rem}.dark-mode .activation-info p{color:#a0aec0}.uploaded-files-list{margin-top:.75rem;padding:.75rem;background:#667eea1a;border-radius:8px;font-size:.9rem;color:#4a5568}.dark-mode .uploaded-files-list{background:#667eea33;color:#cbd5e0}.activation-actions{flex-shrink:0}.btn-activate,.btn-deactivate{padding:1rem 2rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.btn-activate{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;box-shadow:0 4px 12px #48bb784d}.btn-activate:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #48bb7866}.btn-activate:disabled{background:#e2e8f0;color:#a0aec0;cursor:not-allowed;box-shadow:none}.dark-mode .btn-activate:disabled{background:#4a5568;color:#718096}.btn-deactivate{background:linear-gradient(135deg,#fc8181,#f56565);color:#fff;box-shadow:0 4px 12px #f565654d}.btn-deactivate:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f5656566}.activation-warning{margin-top:1rem;padding:1rem;background:#fff5f5;border-left:4px solid #fc8181;border-radius:4px;color:#742a2a;font-size:.9rem}.dark-mode .activation-warning{background:#f5656526;color:#feb2b2}.files-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.file-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 12px #0000000f;transition:all .3s}.file-card:hover{box-shadow:0 4px 20px #0000001a;transform:translateY(-2px)}.dark-mode .file-card{background:#1e1e30;box-shadow:0 2px 12px #0000004d}.dark-mode .file-card:hover{box-shadow:0 4px 20px #0006}.file-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.file-icon{font-size:2rem}.file-title{flex:1}.file-title h3{margin:0 0 .25rem;font-size:1.1rem;color:#2d3748}.dark-mode .file-title h3{color:#e2e8f0}.file-title p{margin:0;font-size:.85rem;color:#718096}.dark-mode .file-title p{color:#a0aec0}.file-status{margin-bottom:1rem;padding:.75rem;border-radius:8px;font-size:.9rem}.file-status.uploaded{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.dark-mode .file-status.uploaded{background:#48bb7826;color:#68d391;border-color:#48bb784d}.file-status.empty{background:#fff3cd;color:#856404;border:1px solid #ffeaa7}.dark-mode .file-status.empty{background:#ed893626;color:#fbd38d;border-color:#ed89364d}.file-info{font-size:.85rem;color:#4a5568;margin:.5rem 0}.dark-mode .file-info{color:#cbd5e0}.upload-zone{border:2px dashed #cbd5e0;border-radius:8px;padding:2rem;text-align:center;cursor:pointer;transition:all .3s;margin-bottom:1rem}.upload-zone:hover{border-color:#f093fb;background:#f093fb0d}.dark-mode .upload-zone{border-color:#4a5568}.dark-mode .upload-zone:hover,.upload-zone.dragging{border-color:#f093fb;background:#f093fb1a}.upload-icon{font-size:3rem;margin-bottom:.5rem}.upload-text{color:#718096;font-size:.9rem;margin:0}.dark-mode .upload-text{color:#a0aec0}.upload-hint{font-size:.75rem;color:#a0aec0;margin-top:.5rem}.dark-mode .upload-hint{color:#718096}.file-actions{display:flex;gap:.5rem}.btn-action{flex:1;padding:.75rem;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-download{background:#e6f7ff;color:#06c}.btn-download:hover{background:#bae7ff}.dark-mode .btn-download{background:#3b82f626;color:#60a5fa}.dark-mode .btn-download:hover{background:#3b82f640}.btn-delete{background:#ffe6e6;color:#c00}.btn-delete:hover{background:#fcc}.dark-mode .btn-delete{background:#ef444426;color:#f87171}.dark-mode .btn-delete:hover{background:#ef444440}.global-actions{margin-top:2rem;display:flex;gap:1rem;justify-content:center}.btn-export,.btn-import,.btn-reset{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-export{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-export:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-import{background:#f7fafc;color:#4a5568;border:2px solid #e2e8f0}.btn-import:hover{background:#edf2f7}.dark-mode .btn-import{background:#2d3748;color:#e2e8f0;border-color:#4a5568}.dark-mode .btn-import:hover{background:#374151}.btn-reset{background:#fff5f5;color:#c53030;border:2px solid #feb2b2}.btn-reset:hover{background:#fed7d7}.dark-mode .btn-reset{background:#ef444426;color:#f87171;border-color:#ef44444d}.dark-mode .btn-reset:hover{background:#ef444440}.loading{text-align:center;padding:2rem;color:#718096}.dark-mode .loading{color:#a0aec0}.toast{position:fixed;bottom:2rem;right:2rem;background:#fff;padding:1rem 1.5rem;border-radius:8px;box-shadow:0 4px 20px #00000026;z-index:10000;animation:slideIn .3s ease-out}.dark-mode .toast{background:#2d3748;color:#e2e8f0}.toast.success{border-left:4px solid #48bb78}.toast.error{border-left:4px solid #f56565}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@media(max-width:768px){.practitioner-portal{padding:1rem .5rem}.practitioner-header{flex-direction:column;gap:1rem;padding:1rem}.practitioner-header h1{font-size:1.4rem}.header-actions{width:100%;justify-content:stretch}.btn-back{flex:1}.files-grid{grid-template-columns:1fr}.activation-header{flex-direction:column;align-items:stretch}.activation-actions,.btn-activate,.btn-deactivate{width:100%}.global-actions{flex-direction:column}.toast{left:1rem;right:1rem;bottom:1rem}}.welcome-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem .75rem;position:relative;overflow-x:hidden;overflow-y:auto}.welcome-card{background:#fff;border-radius:16px;box-shadow:0 20px 80px #0000004d;padding:1.5rem 1.25rem;max-width:550px;width:100%;animation:welcomeSlideUp .6s ease;position:relative;z-index:1}@keyframes welcomeSlideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.welcome-header{text-align:center;margin-bottom:1.5rem}.logo-animated{font-size:3rem;animation:logoFloat 3s ease-in-out infinite;margin-bottom:.5rem}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.welcome-header h1{font-size:2rem;margin-bottom:.25rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800;line-height:1.2}.tagline{color:#7f8c8d;font-size:.9rem;font-weight:500}.welcome-features{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;margin-bottom:1.25rem}.feature-item{display:flex;gap:.5rem;padding:.75rem;background:linear-gradient(135deg,#f8f9ff,#fff);border-radius:8px;border:1px solid #e8e8ff;transition:all .3s}.feature-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea26;border-color:#667eea}.feature-icon{font-size:1.5rem;flex-shrink:0}.feature-item h3{font-size:.8rem;margin-bottom:.15rem;color:#2c3e50;font-weight:700;line-height:1.2}.feature-item p{font-size:.7rem;color:#7f8c8d;line-height:1.3}.welcome-actions{display:flex;flex-direction:column;gap:.65rem;margin-bottom:1.25rem}.btn-welcome{padding:.75rem 1rem;border:none;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:.5rem;position:relative;overflow:hidden}.btn-welcome:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#fff3;transform:translate(-50%,-50%);transition:width .5s,height .5s}.btn-welcome:hover:before{width:300px;height:300px}.btn-icon{font-size:1.1rem;position:relative;z-index:1}.btn-welcome span{position:relative;z-index:1}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 6px 20px #667eea66}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 25px #667eea80}.btn-secondary{background:linear-gradient(135deg,#48c6ef,#6f86d6);color:#fff;box-shadow:0 6px 20px #48c6ef4d}.btn-secondary:hover{transform:translateY(-3px);box-shadow:0 8px 25px #48c6ef66}.btn-guest{background:#fff;color:#333;border:2px solid #e0e0e0}.btn-guest:hover{border-color:#667eea;background:#f8f9fa;transform:translateY(-3px);box-shadow:0 6px 20px #0000001a}.btn-welcome:active{transform:translateY(0)}.welcome-info{margin-bottom:1rem;padding:.75rem;background:#f8f9ff;border-radius:8px;border:1px solid #e8e8ff}.info-toggle{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;font-size:.8rem;padding:0;display:flex;align-items:center;gap:.5rem;width:100%;text-align:left}.info-toggle:hover{color:#764ba2}.info-content{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e8e8ff;animation:infoSlideDown .3s ease}@keyframes infoSlideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.info-content p{margin-bottom:.5rem;font-size:.75rem;color:#555;line-height:1.5}.info-content p:last-child{margin-bottom:0}.info-content strong{color:#333}.welcome-demo{text-align:center;padding:.75rem;background:#fff9e6;border-radius:8px;border:2px dashed #ffe0a3;margin-bottom:1rem}.demo-badge{display:inline-block;background:gold;color:#333;padding:.2rem .75rem;border-radius:20px;font-size:.7rem;font-weight:700;margin-bottom:.35rem}.welcome-demo p{font-size:.75rem;color:#666;line-height:1.4}.welcome-demo code{background:#fff;padding:.2rem .4rem;border-radius:4px;font-family:Courier New,monospace;font-size:.7rem;color:#667eea;border:1px solid #e0e0e0}.welcome-footer{text-align:center;padding-top:1rem;border-top:1px solid #e0e0e0}.welcome-footer p{color:#95a5a6;font-size:.7rem}.welcome-background{position:absolute;inset:0;pointer-events:none;overflow:hidden}.bubble{position:absolute;font-size:3rem;opacity:.15;animation:float 20s ease-in-out infinite}.bubble-1{top:10%;left:10%;animation-delay:0s}.bubble-2{top:20%;right:15%;animation-delay:2s}.bubble-3{bottom:15%;left:15%;animation-delay:4s}.bubble-4{top:60%;right:10%;animation-delay:1s}.bubble-5{bottom:25%;right:25%;animation-delay:3s}.bubble-6{top:40%;left:5%;animation-delay:5s}@keyframes float{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(20px,-30px) rotate(5deg)}50%{transform:translate(-15px,20px) rotate(-5deg)}75%{transform:translate(30px,10px) rotate(3deg)}}@media(max-width:768px){.welcome-container{padding:.5rem}.welcome-card{padding:1.25rem 1rem;border-radius:12px}.welcome-header{margin-bottom:1rem}.welcome-header h1{font-size:1.75rem}.logo-animated{font-size:2.5rem;margin-bottom:.35rem}.tagline{font-size:.85rem}.welcome-features{grid-template-columns:1fr;gap:.5rem;margin-bottom:1rem}.feature-item{padding:.65rem}.feature-icon{font-size:1.25rem}.feature-item h3{font-size:.75rem}.feature-item p{font-size:.65rem}.btn-welcome{padding:.7rem .85rem;font-size:.85rem}.btn-icon{font-size:1rem}.welcome-info{padding:.65rem}.info-toggle{font-size:.75rem}.info-content p{font-size:.7rem}.welcome-demo{padding:.65rem}.demo-badge{font-size:.65rem}.welcome-demo p{font-size:.7rem}.welcome-demo code{font-size:.65rem}.bubble{font-size:1.5rem}}@media(max-width:480px){.welcome-card{padding:1rem .75rem}.welcome-header h1{font-size:1.5rem}.logo-animated{font-size:2rem}.tagline{font-size:.8rem}.feature-item{padding:.5rem}.btn-welcome{padding:.65rem .75rem;font-size:.8rem}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem .75rem;overflow-x:hidden}.auth-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:1.5rem 1.25rem;max-width:450px;width:100%;animation:slideUp .5s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:1.5rem}.auth-header h1{font-size:2rem;margin-bottom:.35rem;color:#333;line-height:1.2}.auth-header h2{font-size:1.5rem;margin-bottom:.35rem;color:#2c3e50;line-height:1.2}.auth-header p{color:#7f8c8d;font-size:.85rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-group label{font-weight:600;color:#2c3e50;font-size:.8rem}.form-group input{padding:.7rem .85rem;border:2px solid #e0e0e0;border-radius:8px;font-size:.9rem;transition:all .3s;background:#f8f9fa;color:#2c3e50!important}.form-group input:-webkit-autofill,.form-group input:-webkit-autofill:hover,.form-group input:-webkit-autofill:focus,.form-group input:-webkit-autofill:active{-webkit-text-fill-color:#2c3e50!important;-webkit-box-shadow:0 0 0 30px #f8f9fa inset!important;transition:background-color 5000s ease-in-out 0s}.form-group input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a;color:#2c3e50!important}.form-group input::placeholder{color:#95a5a6;opacity:1}.form-group input::-webkit-input-placeholder{color:#95a5a6;opacity:1}.form-group input::-moz-placeholder{color:#95a5a6;opacity:1}.input-hint{font-size:.7rem;color:#7f8c8d}.auth-error{background:#fee;color:#c33;padding:.7rem .85rem;border-radius:8px;font-size:.8rem;border-left:4px solid #c33;animation:shake .3s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.btn-auth{padding:.75rem .85rem;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-auth:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea4d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-google{background:#fff;color:#333;border:2px solid #e0e0e0}.btn-google:hover:not(:disabled){border-color:#667eea;background:#f8f9fa}.google-icon{font-size:1.2rem}.auth-divider{display:flex;align-items:center;margin:1rem 0;color:#7f8c8d;font-size:.75rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#e0e0e0}.auth-divider span{padding:0 .75rem;font-weight:600}.auth-footer{text-align:center;margin-top:1rem;padding-top:1rem;border-top:1px solid #e0e0e0}.auth-footer p{color:#7f8c8d;font-size:.85rem}.link-button{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;font-size:inherit;padding:0;text-decoration:underline}.link-button:hover{color:#764ba2}.demo-hint{margin-top:1rem;padding:.75rem;background:#fff9e6;border-radius:8px;font-size:.75rem;color:#666;text-align:center;border:1px solid #ffe0a3;line-height:1.4}@media(max-width:640px){.auth-container{padding:.5rem}.auth-card{padding:1.25rem 1rem;border-radius:12px}.auth-header{margin-bottom:1.25rem}.form-row{grid-template-columns:1fr;gap:1rem}.auth-header h1{font-size:1.75rem}.auth-header h2{font-size:1.35rem}.auth-header p{font-size:.8rem}.form-group label{font-size:.75rem}.form-group input{padding:.65rem .75rem;font-size:.85rem}.btn-auth{padding:.7rem .75rem;font-size:.85rem}.demo-hint{font-size:.7rem}}@media(max-width:480px){.auth-card{padding:1rem .75rem}.auth-header h1{font-size:1.5rem}.auth-header h2{font-size:1.25rem}}.profile-container{max-width:900px;margin:0 auto;padding:2rem 1rem;padding-bottom:100px}.profile-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.profile-header h1{font-size:2rem;color:#2c3e50;margin:0}.btn-logout{padding:.75rem 1.5rem;background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s}.btn-logout:hover{transform:translateY(-2px);box-shadow:0 4px 12px #e74c3c4d}.guest-warning{display:flex;gap:1.5rem;padding:1.5rem;background:linear-gradient(135deg,#fff3cd,#fff8e1);border:2px solid #ffc107;border-radius:12px;margin-bottom:2rem;animation:slideIn .5s ease}.warning-icon{font-size:3rem;flex-shrink:0}.warning-content{flex:1}.warning-content h3{margin:0 0 .75rem;color:#856404;font-size:1.25rem}.warning-content p{margin-bottom:.75rem;color:#664d03;line-height:1.6}.warning-content p:last-of-type{margin-bottom:1rem}.warning-actions{margin-top:1rem}.btn-create-account{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s}.btn-create-account:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.message-banner{padding:1rem;border-radius:10px;margin-bottom:1.5rem;font-weight:600;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.message-banner.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.message-banner.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.profile-section{background:#fff;border-radius:16px;padding:2rem;margin-bottom:1.5rem;box-shadow:0 2px 12px #00000014}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{font-size:1.5rem;color:#2c3e50;margin:0}.btn-edit{padding:.625rem 1.25rem;background:#f8f9fa;border:2px solid #e0e0e0;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;color:#667eea}.btn-edit:hover{background:#667eea;color:#fff;border-color:#667eea}.info-display{display:flex;flex-direction:column;gap:1rem}.info-item{display:flex;justify-content:space-between;padding:.875rem 0;border-bottom:1px solid #f0f0f0}.info-item:last-child{border-bottom:none}.info-label{font-weight:600;color:#7f8c8d;font-size:.95rem}.info-value{font-weight:600;color:#2c3e50;font-size:.95rem}.no-profile{text-align:center;color:#7f8c8d;padding:2rem;font-style:italic}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group.full-width{grid-column:1 / -1}.form-group label{font-weight:600;color:#2c3e50;font-size:.9rem}.form-group input,.form-group select{padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:all .3s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.disabled-input{background:#f8f9fa;color:#7f8c8d;cursor:not-allowed}.input-hint{font-size:.8rem;color:#7f8c8d}.form-actions{display:flex;gap:1rem;justify-content:flex-end}.btn-save{padding:.875rem 2rem;background:linear-gradient(135deg,#56ab2f,#a8e063);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s}.btn-save:hover{transform:translateY(-2px);box-shadow:0 4px 12px #56ab2f4d}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:1.5rem;background:#f8f9fa;border-radius:12px;border:2px solid #e0e0e0}.stat-label{color:#7f8c8d;font-size:.85rem;margin-bottom:.25rem}.stat-value{font-weight:700;color:#2c3e50;font-size:1.1rem}.danger-zone{border:2px solid #e74c3c;background:#fee}.danger-zone h2{color:#c0392b}.danger-zone p{color:#721c24;margin-bottom:1rem}.btn-danger{padding:.875rem 2rem;background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 4px 12px #e74c3c66}@media(max-width:768px){.profile-container{padding:1rem;padding-bottom:100px}.profile-header{flex-direction:column;gap:1rem;align-items:flex-start}.form-grid,.stats-grid{grid-template-columns:1fr}.info-item{flex-direction:column;gap:.5rem;align-items:flex-start}}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;gap:1.5rem}.loading-state .spinner{width:50px;height:50px;border:4px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}.loading-state p{font-size:1rem;color:var(--text-secondary);margin:0}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;gap:1.5rem;padding:2rem}.error-icon{font-size:4rem;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.error-state h2{font-size:1.5rem;color:var(--danger);margin:0}.error-state p{font-size:1rem;color:var(--text-secondary);margin:0;max-width:400px}.error-actions{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.btn-retry,.btn-back{padding:.75rem 1.5rem;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s}.btn-retry{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff}.btn-retry:hover{transform:translateY(-2px);box-shadow:0 4px 12px #4caf504d}.btn-back{background:var(--card-bg);color:var(--text-primary);border:2px solid var(--border-color)}.btn-back:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.no-user-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;gap:1.5rem;padding:2rem}.no-user-icon{font-size:4rem;opacity:.5}.no-user-state h2{font-size:1.5rem;color:var(--text-primary);margin:0}.no-user-state p{font-size:1rem;color:var(--text-secondary);margin:0;max-width:400px}.btn-login{padding:.75rem 2rem;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s}.btn-login:hover{transform:translateY(-2px);box-shadow:0 4px 12px #4caf504d}.history-container{max-width:900px;margin:0 auto;padding:2rem 1rem;padding-bottom:100px}.history-header{text-align:center;margin-bottom:2rem}.history-header h1{font-size:2rem;color:#2c3e50;margin-bottom:.5rem}.history-subtitle{color:#7f8c8d;font-size:.95rem}.guest-mode-message{text-align:center;padding:4rem 2rem;background:linear-gradient(135deg,#fff3cd,#fff8e1);border:2px solid #ffc107;border-radius:16px;box-shadow:0 2px 12px #00000014}.guest-icon{font-size:4rem;display:block;margin-bottom:1rem}.guest-mode-message h3{color:#856404;margin-bottom:1rem;font-size:1.5rem}.guest-mode-message p{color:#664d03;max-width:500px;margin:0 auto 1rem;line-height:1.6}.empty-history{text-align:center;padding:4rem 2rem;background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000014}.empty-icon{font-size:4rem;display:block;margin-bottom:1rem;opacity:.5}.empty-history h3{color:#2c3e50;margin-bottom:.5rem}.empty-history p{color:#7f8c8d;max-width:400px;margin:0 auto}.history-list{display:flex;flex-direction:column;gap:1.5rem}.history-item{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 2px 12px #00000014;transition:all .3s}.history-item:hover{transform:translateY(-4px);box-shadow:0 4px 20px #0000001f}.history-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #f0f0f0}.history-number{font-size:1.5rem;font-weight:700;color:#667eea}.history-date{color:#7f8c8d;font-size:.9rem;font-weight:600}.history-preview h3{font-size:1.1rem;color:#2c3e50;margin-bottom:1rem}.menu-days-preview{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem;margin-bottom:1rem}.day-preview{background:#f8f9fa;padding:.75rem;border-radius:10px;display:flex;flex-direction:column;align-items:center;gap:.5rem;border:2px solid #e0e0e0}.day-name{font-weight:600;color:#2c3e50;font-size:.85rem}.meals-count{font-size:1.2rem}.day-preview.more{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;justify-content:center;font-weight:600;border-color:#667eea}.history-actions{display:flex;gap:1rem}.btn-load,.btn-details{flex:1;padding:.875rem;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s}.btn-load{background:linear-gradient(135deg,#56ab2f,#a8e063);color:#fff}.btn-load:hover{transform:translateY(-2px);box-shadow:0 4px 12px #56ab2f4d}.btn-details{background:#f8f9fa;color:#667eea;border:2px solid #e0e0e0}.btn-details:hover{background:#667eea;color:#fff;border-color:#667eea}@media(max-width:768px){.history-container{padding:1rem;padding-bottom:100px}.menu-days-preview{grid-template-columns:repeat(2,1fr)}.history-actions{flex-direction:column}}.favorites-container{max-width:1200px;margin:0 auto;padding:2rem 1rem;min-height:calc(100vh - 80px)}.favorites-header{text-align:center;margin-bottom:2rem}.favorites-header h1{font-size:2.5rem;margin-bottom:.5rem;color:var(--text-primary)}.favorites-count{color:var(--text-secondary);font-size:1.1rem}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem}.no-user-message{text-align:center;padding:3rem;background:var(--background-secondary);border-radius:12px;margin:2rem auto;max-width:500px}.no-user-message h2{margin-bottom:1rem;color:var(--text-primary)}.no-user-message p{margin-bottom:.5rem;color:var(--text-secondary)}.favorites-stats{background:var(--background-secondary);border-radius:12px;padding:1rem;margin-bottom:2rem}.stats-toggle{width:100%;background:none;border:none;color:var(--text-primary);font-size:1.1rem;font-weight:600;cursor:pointer;text-align:left;padding:.5rem}.stats-content{padding:1rem 0;display:flex;flex-direction:column;gap:1rem}.stat-item{display:flex;justify-content:space-between;align-items:center}.stat-label{color:var(--text-secondary);font-weight:500}.stat-value{color:var(--primary-color);font-weight:700;font-size:1.2rem}.stat-breakdown{display:flex;gap:1rem}.stat-breakdown span{color:var(--text-primary);font-weight:600}.favorites-controls{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem;padding:1rem;background:var(--background-secondary);border-radius:12px}.search-bar{flex:1;min-width:250px}.search-bar input{width:100%;padding:.75rem 1rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;background:var(--background-primary);color:var(--text-primary);transition:border-color .3s}.search-bar input:focus{outline:none;border-color:var(--primary-color)}.filter-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.filter-btn{padding:.75rem 1rem;border:2px solid var(--border-color);border-radius:8px;background:var(--background-primary);color:var(--text-primary);font-weight:600;cursor:pointer;transition:all .3s}.filter-btn:hover{border-color:var(--primary-color);background:var(--primary-color);color:#fff}.filter-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.sort-controls{display:flex;align-items:center;gap:.5rem}.sort-controls label{font-weight:600;color:var(--text-primary)}.sort-controls select{padding:.75rem 1rem;border:2px solid var(--border-color);border-radius:8px;background:var(--background-primary);color:var(--text-primary);font-size:1rem;cursor:pointer}.export-controls{display:flex;gap:.5rem;margin-left:auto}.btn-export,.btn-import{padding:.75rem 1rem;border:2px solid var(--primary-color);border-radius:8px;background:var(--primary-color);color:#fff;font-weight:600;cursor:pointer;transition:all .3s}.btn-export:hover,.btn-import:hover{background:var(--primary-hover)}.btn-import{display:inline-block}.empty-state{text-align:center;padding:3rem;color:var(--text-secondary);font-size:1.1rem}.empty-state p{margin-bottom:.5rem}.favorites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.favorite-card{position:relative;background:var(--background-secondary);border:2px solid var(--border-color);border-radius:12px;padding:1.5rem;transition:all .3s}.favorite-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001a}.badge-new{position:absolute;top:10px;right:10px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.favorite-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.favorite-header h3{font-size:1.3rem;color:var(--text-primary);margin:0;flex:1}.btn-remove{background:none;border:none;font-size:1.2rem;cursor:pointer;opacity:.6;transition:opacity .3s}.btn-remove:hover{opacity:1}.favorite-type{display:inline-block;background:var(--background-primary);color:var(--text-primary);padding:.5rem 1rem;border-radius:20px;font-size:.9rem;margin-bottom:.75rem}.favorite-calories{font-size:1.5rem;font-weight:700;color:var(--primary-color);margin-bottom:1rem}.favorite-macros{display:flex;justify-content:space-between;padding:.75rem;background:var(--background-primary);border-radius:8px;margin-bottom:1rem}.favorite-macros span{font-size:.9rem;font-weight:600;color:var(--text-primary)}.favorite-notes{background:#fffbea;padding:.75rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem;color:#333}.favorite-date{font-size:.85rem;color:var(--text-secondary);margin-bottom:1rem}.favorite-actions{display:flex;gap:.5rem}.btn-view,.btn-note{flex:1;padding:.75rem;border:2px solid var(--primary-color);border-radius:8px;background:var(--background-primary);color:var(--primary-color);font-weight:600;cursor:pointer;transition:all .3s}.btn-view:hover,.btn-note:hover{background:var(--primary-color);color:#fff}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--background-primary);border-radius:12px;padding:2rem;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;position:relative}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-primary)}.modal-content h2{color:var(--text-primary);margin-bottom:1rem}.modal-type{display:inline-block;background:var(--background-secondary);padding:.5rem 1rem;border-radius:20px;margin-bottom:1rem}.modal-calories{font-size:1.8rem;font-weight:700;color:var(--primary-color);margin-bottom:1rem}.modal-macros{display:flex;justify-content:space-around;padding:1rem;background:var(--background-secondary);border-radius:8px;margin-bottom:1.5rem}.modal-macros span{font-weight:600;color:var(--text-primary)}.modal-section{margin-bottom:1.5rem}.modal-section h3{color:var(--text-primary);margin-bottom:.75rem}.modal-section ul{list-style:none;padding:0}.modal-section ul li{padding:.5rem;background:var(--background-secondary);margin-bottom:.5rem;border-radius:6px;color:var(--text-primary)}.modal-note textarea{width:100%;min-height:120px;padding:1rem;border:2px solid var(--border-color);border-radius:8px;font-family:inherit;font-size:1rem;resize:vertical;background:var(--background-secondary);color:var(--text-primary)}.note-char-count{text-align:right;font-size:.85rem;color:var(--text-secondary);margin-bottom:1rem}.modal-actions{display:flex;gap:1rem}.btn-save,.btn-cancel{flex:1;padding:1rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s}.btn-save{background:var(--primary-color);color:#fff}.btn-save:hover{background:var(--primary-hover)}.btn-cancel{background:var(--background-secondary);color:var(--text-primary)}.btn-cancel:hover{background:var(--border-color)}@media(max-width:768px){.favorites-container{padding:1rem .5rem}.favorites-header h1{font-size:2rem}.favorites-controls{flex-direction:column}.export-controls{margin-left:0}.favorites-grid{grid-template-columns:1fr}.modal-content{padding:1.5rem}.modal-macros{flex-direction:column;gap:.5rem}}.hydration-container{max-width:800px;margin:0 auto;padding:2rem 1rem;min-height:calc(100vh - 80px)}.hydration-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.hydration-header h1{font-size:2.5rem;color:var(--text-primary);margin:0}.btn-settings{background:var(--background-secondary);border:2px solid var(--border-color);border-radius:50%;width:50px;height:50px;font-size:1.5rem;cursor:pointer;transition:all .3s}.btn-settings:hover{transform:rotate(90deg);background:var(--primary-color)}.loading-state,.no-user-message{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;text-align:center}.spinner{width:50px;height:50px;border:4px solid var(--background-secondary);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.settings-panel{background:var(--background-secondary);border:2px solid var(--border-color);border-radius:12px;padding:1.5rem;margin-bottom:2rem}.settings-panel h3{margin-top:0;color:var(--text-primary)}.setting-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.75rem;background:var(--background-primary);border-radius:8px}.setting-item label{font-weight:600;color:var(--text-primary)}.goal-display,.goal-edit{display:flex;align-items:center;gap:.5rem}.goal-edit input{width:100px;padding:.5rem;border:2px solid var(--border-color);border-radius:6px;background:var(--background-primary);color:var(--text-primary)}.btn-edit,.btn-save,.btn-cancel{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:.25rem .5rem}.toggle-btn{padding:.5rem 1rem;border:2px solid var(--border-color);border-radius:20px;background:var(--background-primary);color:var(--text-primary);cursor:pointer;transition:all .3s}.toggle-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.setting-info{margin-top:1rem;padding:1rem;background:#e3f2fd;border-radius:8px;color:#1976d2;font-size:.9rem}.celebration-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .3s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.celebration-content{background:#fff;padding:3rem;border-radius:20px;text-align:center;animation:zoomIn .5s}@keyframes zoomIn{0%{transform:scale(.5)}to{transform:scale(1)}}.confetti{font-size:5rem;animation:bounce 1s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.celebration-content h2{color:#4caf50;margin:1rem 0}.today-progress{background:var(--background-secondary);border:2px solid var(--border-color);border-radius:12px;padding:2rem;margin-bottom:2rem;text-align:center}.progress-header h2{color:var(--text-primary);margin:0 0 .5rem}.motivation-message{color:var(--text-secondary);font-size:1.1rem;margin:0}.circular-progress{position:relative;width:200px;height:200px;margin:2rem auto}.progress-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.percentage{font-size:2.5rem;font-weight:700;color:var(--primary-color)}.amount{font-size:1.2rem;font-weight:600;color:var(--text-primary)}.goal{font-size:.9rem;color:var(--text-secondary)}.remaining{margin-top:1rem;padding:1rem;background:var(--background-primary);border-radius:8px;color:var(--text-primary)}.goal-reached{margin-top:1rem;padding:1rem;background:#4caf50;color:#fff;border-radius:8px;font-weight:600;font-size:1.1rem}.streak{display:block;margin-top:.5rem;font-size:1rem}.quick-actions{background:var(--background-secondary);border:2px solid var(--border-color);border-radius:12px;padding:1.5rem;margin-bottom:2rem}.quick-actions h3{margin-top:0;color:var(--text-primary);text-align:center}.quick-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1rem}.btn-quick{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem 1rem;background:var(--background-primary);border:2px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .3s}.btn-quick:hover{transform:translateY(-4px);box-shadow:0 4px 12px #0000001a;border-color:var(--primary-color)}.btn-quick .icon{font-size:2rem}.btn-quick .label{font-weight:700;font-size:1.1rem;color:var(--text-primary)}.btn-quick .sublabel{font-size:.85rem;color:var(--text-secondary)}.custom-amount{display:flex;gap:.5rem}.custom-amount input{flex:1;padding:.75rem 1rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;background:var(--background-primary);color:var(--text-primary)}.btn-add{padding:.75rem 1.5rem;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s}.btn-add:hover{background:var(--primary-hover)}.today-entries{background:var(--background-secondary);border:2px solid var(--border-color);border-radius:12px;padding:1.5rem;margin-bottom:2rem}.today-entries h3{margin-top:0;color:var(--text-primary)}.entries-list{display:flex;flex-direction:column;gap:.5rem}.entry-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--background-primary);border-radius:8px}.entry-time{color:var(--text-secondary);font-size:.9rem}.entry-amount{font-weight:600;color:var(--primary-color)}.btn-remove-entry{background:none;border:none;color:#f44;font-size:1.2rem;cursor:pointer;opacity:.6;transition:opacity .3s}.btn-remove-entry:hover{opacity:1}.week-history{background:var(--background-secondary);border:2px solid var(--border-color);border-radius:12px;padding:1.5rem;margin-bottom:2rem}.week-history h3{margin-top:0;color:var(--text-primary)}.history-chart{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;margin-top:1rem}.history-day{display:flex;flex-direction:column;align-items:center;gap:.5rem}.day-name{font-weight:600;color:var(--text-primary);font-size:.9rem}.day-bar-container{position:relative;width:100%;height:120px;background:var(--background-primary);border-radius:8px;display:flex;align-items:flex-end;justify-content:center}.day-bar{width:60%;border-radius:4px 4px 0 0;transition:height .5s ease;min-height:2px}.day-badge{position:absolute;top:5px;right:5px;font-size:1rem}.day-percentage{font-size:.9rem;font-weight:600;color:var(--text-primary)}.day-amount{font-size:.85rem;color:var(--text-secondary)}.week-stats{background:var(--background-secondary);border:2px solid var(--border-color);border-radius:12px;padding:1.5rem;margin-bottom:2rem}.week-stats h3{margin-top:0;color:var(--text-primary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-top:1rem}.stat-card{background:var(--background-primary);border:2px solid var(--border-color);border-radius:12px;padding:1.5rem;text-align:center;transition:all .3s}.stat-card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #0000001a}.stat-icon{font-size:2.5rem;margin-bottom:.5rem}.stat-label{font-size:.9rem;color:var(--text-secondary);margin-bottom:.5rem}.stat-value{font-size:2rem;font-weight:700;color:var(--primary-color);margin-bottom:.25rem}.stat-sub{font-size:.85rem;color:var(--text-secondary)}.hydration-tips{background:#e3f2fd;border:2px solid #2196F3;border-radius:12px;padding:1.5rem;margin-bottom:2rem}.hydration-tips h3{margin-top:0;color:#1976d2}.hydration-tips ul{list-style:none;padding:0;margin:0}.hydration-tips li{padding:.75rem;background:#fff;margin-bottom:.5rem;border-radius:8px;color:#333}[data-theme=dark] .hydration-tips{background:#1a237e;border-color:#3f51b5}[data-theme=dark] .hydration-tips h3{color:#90caf9}[data-theme=dark] .hydration-tips li{background:#283593;color:#e3f2fd}[data-theme=dark] .setting-info{background:#1a237e;color:#90caf9}[data-theme=dark] .celebration-content{background:var(--background-secondary);color:var(--text-primary)}@media(max-width:768px){.hydration-container{padding:1rem .5rem}.hydration-header h1{font-size:2rem}.quick-buttons{grid-template-columns:1fr}.history-chart{gap:.25rem}.day-bar-container{height:100px}.stats-grid{grid-template-columns:repeat(2,1fr)}.circular-progress{width:180px;height:180px}.circular-progress svg{width:180px;height:180px}}@media(max-width:480px){.hydration-header h1{font-size:1.75rem}.stats-grid{grid-template-columns:1fr}}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;box-shadow:0 -4px 20px #0000001a;display:flex;justify-content:space-around;padding:.5rem 0;z-index:1000;border-top:1px solid #e0e0e0}.nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem .5rem;background:none;border:none;cursor:pointer;transition:all .3s;color:#7f8c8d;position:relative}.nav-tab:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:0;height:3px;background:linear-gradient(135deg,#667eea,#764ba2);transition:width .3s;border-radius:0 0 3px 3px}.nav-tab.active:before{width:60%}.nav-tab.active{color:#667eea}.tab-icon{font-size:1.5rem;transition:transform .3s}.nav-tab:active .tab-icon{transform:scale(.9)}.nav-tab.active .tab-icon{transform:scale(1.1)}.tab-label{font-size:.75rem;font-weight:600;text-align:center}.nav-tab:hover:not(.active){color:#667eea;background:#667eea0d}@media(max-width:480px){.tab-label{font-size:.7rem}.tab-icon{font-size:1.25rem}}.theme-toggle{position:fixed;top:20px;right:20px;z-index:1000;width:50px;height:50px;border-radius:50%;background:var(--card-bg);border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-md)}.theme-toggle:hover{transform:scale(1.1);box-shadow:var(--shadow-lg);border-color:var(--accent-primary)}.theme-toggle:active{transform:scale(.95)}.theme-icon{font-size:24px;display:flex;align-items:center;justify-content:center;transition:transform .3s ease}.theme-toggle:hover .theme-icon{transform:rotate(20deg)}@keyframes fadeInSlide{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.theme-toggle{animation:fadeInSlide .5s ease}@media(max-width:768px){.theme-toggle{top:15px;right:15px;width:45px;height:45px}.theme-icon{font-size:20px}}.theme-toggle:focus{outline:3px solid var(--accent-primary);outline-offset:2px}.theme-toggle:focus:not(:focus-visible){outline:none}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);font-size:16px;line-height:1.6;letter-spacing:-.2px;transition:background-color .3s ease,color .3s ease}.app{min-height:100vh;max-width:100%;margin:0 auto;position:relative;background-color:var(--bg-primary)}.app-content{min-height:100vh;padding-bottom:80px}.admin-access-btn{position:fixed;bottom:2rem;right:2rem;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff;font-size:1.5rem;cursor:pointer;box-shadow:0 4px 16px #667eea66;transition:all .3s ease;z-index:1000;display:flex;align-items:center;justify-content:center}.admin-access-btn:hover{transform:scale(1.1) rotate(90deg);box-shadow:0 6px 24px #667eea99}.admin-access-btn:active{transform:scale(.95)}.practitioner-access-btn{position:fixed;bottom:6rem;right:2rem;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#f093fb,#f5576c);border:none;color:#fff;font-size:1.5rem;cursor:pointer;box-shadow:0 4px 16px #f093fb66;transition:all .3s ease;z-index:1000;display:flex;align-items:center;justify-content:center}.practitioner-access-btn:hover{transform:scale(1.1);box-shadow:0 6px 24px #f093fb99}.practitioner-access-btn:active{transform:scale(.95)}@media(min-width:768px){.app{max-width:600px}}button,input,select,textarea{min-height:44px;font-size:16px}html{scroll-behavior:smooth}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease-in-out}
