body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--bg-primary:#fff;--bg-secondary:#f8f9fa;--bg-tertiary:#e9ecef;--text-primary:#212529;--text-secondary:#6c757d;--text-muted:#adb5bd;--border-color:#dee2e6;--shadow-color:#0000001a;--accent-primary:#3498db;--accent-primary-hover:#2980b9;--accent-success:#27ae60;--accent-success-hover:#229954;--accent-danger:#e74c3c;--accent-danger-hover:#c0392b;--accent-secondary:#95a5a6;--accent-secondary-hover:#7f8c8d;--nav-bg:#2c3e50;--nav-hover:#34495e}[data-theme=dark]{--bg-primary:#1e1e1e;--bg-secondary:#2d2d2d;--bg-tertiary:#3d3d3d;--text-primary:#fff;--text-secondary:#b0b0b0;--text-muted:#888;--border-color:#404040;--shadow-color:#0000004d;--accent-primary:#4dabf7;--accent-primary-hover:#339af0;--accent-success:#51cf66;--accent-success-hover:#40c057;--accent-danger:#ff6b6b;--accent-danger-hover:#fa5252;--accent-secondary:#868e96;--accent-secondary-hover:#748ffc;--nav-bg:#1a1a1a;--nav-hover:#2d2d2d}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa;background-color:var(--bg-secondary);color:#212529;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;transition:background-color .3s ease,color .3s ease}.App{min-height:100vh}.main-content{margin:0 auto;max-width:1200px;padding:20px}.navigation{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#2c3e50;background-color:var(--nav-bg);box-shadow:0 4px 12px #0000001a;box-shadow:0 4px 12px var(--shadow-color);color:#fff;padding:1rem 0;position:-webkit-sticky;position:sticky;top:0;transition:all .3s ease;z-index:100}.nav-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 20px}.nav-brand{color:#fff;font-size:1.5rem;font-weight:700;text-decoration:none;transition:transform .2s ease}.nav-brand:hover{transform:scale(1.05)}.nav-links{align-items:center;display:flex;gap:1rem;list-style:none}.nav-links a{border-radius:8px;color:#fff;display:block;font-weight:500;overflow:hidden;padding:.75rem 1.25rem;position:relative;text-decoration:none;transition:all .2s ease}.nav-links a:before{background:linear-gradient(90deg,#0000,#ffffff1a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.nav-links a:hover:before{left:100%}.nav-links a.active,.nav-links a:hover{background-color:#34495e;background-color:var(--nav-hover);box-shadow:0 4px 8px #0000001a;box-shadow:0 4px 8px var(--shadow-color);transform:translateY(-2px)}.theme-toggle{align-items:center;background:#ffffff1a;border:2px solid #fff3;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:44px;justify-content:center;margin-left:1rem;padding:.5rem;transition:all .3s ease;width:44px}.theme-toggle:hover{background:#fff3;border-color:#fff6;transform:rotate(180deg) scale(1.1)}.card{background:#fff;background:var(--bg-primary);border:1px solid #dee2e6;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 16px #0000001a;box-shadow:0 4px 16px var(--shadow-color);margin-bottom:1.5rem;overflow:hidden;padding:1.5rem;position:relative;transition:all .3s ease}.card:before{background:linear-gradient(90deg,#3498db,#27ae60);background:linear-gradient(90deg,var(--accent-primary),var(--accent-success));content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.card:hover{box-shadow:0 8px 32px #0000001a;box-shadow:0 8px 32px var(--shadow-color);transform:translateY(-4px)}.card:hover:before{opacity:1}.card h2{color:#212529;color:var(--text-primary);font-size:1.25rem;font-weight:600;margin-bottom:1rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#212529;color:var(--text-primary);display:block;font-size:.9rem;font-weight:600;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.form-group input,.form-group select,.form-group textarea{background-color:#fff;background-color:var(--bg-primary);border:2px solid #dee2e6;border:2px solid var(--border-color);border-radius:8px;color:#212529;color:var(--text-primary);font-size:1rem;padding:.875rem 1rem;transition:all .3s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3498db;border-color:var(--accent-primary);box-shadow:0 0 0 3px #3498db1a;outline:none;transform:translateY(-1px)}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;justify-content:center;margin-bottom:.75rem;margin-right:.75rem;min-height:44px;overflow:hidden;padding:.875rem 1.75rem;position:relative;text-decoration:none;transition:all .3s ease}.btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.btn:hover:before{left:100%}.btn:hover{box-shadow:0 8px 24px #0000001a;box-shadow:0 8px 24px var(--shadow-color);transform:translateY(-2px)}.btn:active{transform:translateY(0)}.btn-primary{background:linear-gradient(135deg,#3498db,#2980b9);background:linear-gradient(135deg,var(--accent-primary),var(--accent-primary-hover));color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#2980b9,#3498db);background:linear-gradient(135deg,var(--accent-primary-hover),var(--accent-primary))}.btn-success{background:linear-gradient(135deg,#27ae60,#229954);background:linear-gradient(135deg,var(--accent-success),var(--accent-success-hover));color:#fff}.btn-success:hover{background:linear-gradient(135deg,#229954,#27ae60);background:linear-gradient(135deg,var(--accent-success-hover),var(--accent-success))}.btn-danger{background:linear-gradient(135deg,#e74c3c,#c0392b);background:linear-gradient(135deg,var(--accent-danger),var(--accent-danger-hover));color:#fff}.btn-danger:hover{background:linear-gradient(135deg,#c0392b,#e74c3c);background:linear-gradient(135deg,var(--accent-danger-hover),var(--accent-danger))}.btn-secondary{background:linear-gradient(135deg,#95a5a6,#7f8c8d);background:linear-gradient(135deg,var(--accent-secondary),var(--accent-secondary-hover));color:#fff}.btn-secondary:hover{background:linear-gradient(135deg,#7f8c8d,#95a5a6);background:linear-gradient(135deg,var(--accent-secondary-hover),var(--accent-secondary))}.search-bar{margin-bottom:1.5rem;position:relative}.search-bar input{background-color:#fff;background-color:var(--bg-primary);border:2px solid #dee2e6;border:2px solid var(--border-color);border-radius:12px;box-shadow:0 2px 8px #0000001a;box-shadow:0 2px 8px var(--shadow-color);color:#212529;color:var(--text-primary);font-size:1rem;padding:1rem 1.25rem;transition:all .3s ease;width:100%}.search-bar input:focus{border-color:#3498db;border-color:var(--accent-primary);box-shadow:0 4px 16px #0000001a,0 0 0 3px #3498db1a;box-shadow:0 4px 16px var(--shadow-color),0 0 0 3px #3498db1a;outline:none;transform:translateY(-2px)}.grid{grid-gap:1rem;display:grid;gap:1rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.dish-card{background:#fff;background:var(--bg-primary);border:1px solid #dee2e6;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 12px #0000001a;box-shadow:0 4px 12px var(--shadow-color);cursor:pointer;overflow:hidden;padding:1.25rem;position:relative;transition:all .3s ease}.dish-card:before{background:linear-gradient(90deg,#27ae60,#3498db);background:linear-gradient(90deg,var(--accent-success),var(--accent-primary));content:"";height:3px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.dish-card:hover{box-shadow:0 12px 32px #0000001a;box-shadow:0 12px 32px var(--shadow-color);transform:translateY(-6px)}.dish-card:hover:before{transform:scaleX(1)}.dish-card h3{color:#212529;color:var(--text-primary);font-size:1.1rem;font-weight:600;margin-bottom:.75rem}.dish-card h3 a{color:inherit;text-decoration:none;transition:color .2s ease}.dish-card h3 a:hover{color:#3498db;color:var(--accent-primary)}.dish-category{background:linear-gradient(135deg,#3498db,#27ae60);background:linear-gradient(135deg,var(--accent-primary),var(--accent-success));border-radius:16px;color:#fff;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.5px;margin-bottom:.75rem;padding:.375rem .75rem;text-transform:uppercase}.dish-ingredients{color:#6c757d;color:var(--text-secondary);font-size:.9rem;line-height:1.4;margin-bottom:.5rem}.ingredient-item{background-color:#e9ecef;background-color:var(--bg-tertiary);border:1px solid #dee2e6;border:1px solid var(--border-color);border-radius:4px;margin-bottom:.5rem;padding:.75rem;transition:background-color .3s ease,border-color .3s ease}.ingredient-note{color:#6c757d;color:var(--text-secondary);font-size:.9rem;margin-top:.25rem}.ingredient-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.ingredient-tag{background-color:#3498db;background-color:var(--accent-primary);border-radius:16px;font-size:.9rem;gap:.5rem;padding:.25rem .75rem}.ingredient-tag,.ingredient-tag button{align-items:center;color:#fff;display:flex}.ingredient-tag button{background:none;border:none;border-radius:50%;cursor:pointer;font-size:1rem;height:16px;justify-content:center;padding:0;width:16px}.ingredient-tag button:hover{background-color:#fff3}.dish-score{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.score-bar{background-color:#e9ecef;background-color:var(--bg-tertiary);border-radius:4px;height:8px;overflow:hidden;width:100px}.score-fill{background-color:#27ae60;background-color:var(--accent-success);height:100%;transition:width .3s ease}.missing-ingredients{color:#e74c3c;color:var(--accent-danger);font-size:.8rem;margin-top:.5rem}.calendar-container{background:#fff;background:var(--bg-primary);border:1px solid #dee2e6;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 8px #0000001a;box-shadow:0 2px 8px var(--shadow-color);padding:1rem}.calendar-day{border-radius:4px;cursor:pointer;padding:.5rem;transition:background-color .2s}.calendar-day:hover{background-color:#f8f9fa;background-color:var(--bg-secondary)}.has-meals{background-color:#27ae602e}.loading{align-items:center;color:#6c757d;color:var(--text-secondary);display:flex;flex-direction:column;gap:1rem;padding:3rem;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #dee2e6;border-top:4px solid #3498db;border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--accent-primary);height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-text{font-size:1.1rem;font-weight:500}.error{align-items:center;background:linear-gradient(135deg,#e74c3c1a,#e74c3c0d);border:2px solid #e74c3c33;border-radius:12px;color:#e74c3c;color:var(--accent-danger);display:flex;font-weight:500;gap:.75rem;margin-bottom:1.5rem;padding:1.25rem}.error:before{content:"⚠️";font-size:1.2rem}.mobile-menu-button{background:#0000;border:none;cursor:pointer;display:none;flex-direction:column;height:2rem;justify-content:space-around;padding:0;width:2rem;z-index:101}.mobile-menu-button span{background:#fff;border-radius:10px;height:.25rem;position:relative;transform-origin:1px;transition:all .3s linear;width:2rem}.mobile-menu-button span:first-child.open{transform:rotate(45deg)}.mobile-menu-button span:nth-child(2).open{opacity:0;transform:translateX(20px)}.mobile-menu-button span:nth-child(3).open{transform:rotate(-45deg)}@media (max-width:768px){.mobile-menu-button{display:flex}.nav-container{position:relative}.nav-links{background-color:#2c3e50;background-color:var(--nav-bg);box-shadow:-4px 0 12px #0000001a;box-shadow:-4px 0 12px var(--shadow-color);flex-direction:column;gap:.5rem;height:100vh;padding:5rem 1.5rem 2rem;position:fixed;right:0;top:0;transform:translateX(100%);transition:transform .3s ease-in-out;width:250px;z-index:100}.nav-links.mobile-open{transform:translateX(0)}.nav-links li{width:100%}.nav-links a{display:block;text-align:left;width:100%}.main-content{padding:10px}.grid-2,.grid-3{grid-template-columns:1fr}.btn{margin-right:0}}:focus-visible{outline:3px solid #3498db;outline:3px solid var(--accent-primary);outline-offset:2px}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.001ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.001ms!important}.btn:hover,.card:hover,.dish-card:hover,.language-item:hover,.nav-links a:hover,.theme-toggle:hover{transform:none!important}}
/*# sourceMappingURL=main.dba6550f.css.map*/