@import"https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@300;400;600;700&family=Karla:wght@300;400;500;600&display=swap";.navbar{background:var(--cream);border-bottom:1px solid rgba(107,127,94,.15);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:slideInLeft .5s ease-out}.navbar-container{max-width:1200px;margin:0 auto;padding:var(--spacing-sm) var(--spacing-md);display:flex;justify-content:space-between;align-items:center;position:relative}.navbar-logo{display:flex;align-items:center;gap:.75rem;font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--deep-brown);transition:var(--transition);min-width:0}.navbar-logo:hover{transform:translateY(-2px)}.logo-icon{font-size:1.75rem;display:flex;align-items:center}.logo-text{letter-spacing:-.5px;white-space:nowrap}.navbar-toggle{display:none;width:44px;height:40px;border-radius:12px;border:1px solid rgba(107,127,94,.2);background:#ffffff73;box-shadow:0 2px 8px var(--shadow);cursor:pointer;transition:var(--transition);position:relative}.navbar-toggle:hover{transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow-hover)}.toggle-bar{position:absolute;left:50%;top:50%;width:20px;height:2px;background:var(--deep-brown);border-radius:999px;transform-origin:center;transition:.2s ease}.toggle-bar:nth-child(1){transform:translate(-50%,-50%) translateY(-7px)}.toggle-bar:nth-child(2){transform:translate(-50%,-50%)}.toggle-bar:nth-child(3){transform:translate(-50%,-50%) translateY(7px)}.navbar-toggle.open .toggle-bar:nth-child(1){transform:translate(-50%,-50%) rotate(45deg)}.navbar-toggle.open .toggle-bar:nth-child(2){opacity:0;transform:translate(-50%,-50%) scaleX(.6)}.navbar-toggle.open .toggle-bar:nth-child(3){transform:translate(-50%,-50%) rotate(-45deg)}.navbar-menu{display:flex;align-items:center;gap:var(--spacing-md)}.nav-link{position:relative;padding:.5rem 1rem;color:var(--charcoal);font-weight:500;transition:var(--transition);border-radius:8px;white-space:nowrap}.nav-link:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:0;height:2px;background:var(--terracotta);transition:var(--transition)}.nav-link:hover{color:var(--terracotta);background:#d4765e0d}.nav-link:hover:after{width:60%}.nav-link.active{color:var(--terracotta);background:#d4765e1a}.nav-link.active:after{width:60%}.navbar-user{display:flex;align-items:center;gap:var(--spacing-sm);padding-left:var(--spacing-md);border-left:1px solid rgba(107,127,94,.2)}.user-name{color:var(--deep-brown);font-weight:500;font-size:.95rem;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-btn{padding:.5rem 1.25rem;background:var(--olive);color:#fff;border-radius:8px;font-weight:500;transition:var(--transition);box-shadow:0 2px 8px var(--shadow);border:none;cursor:pointer;white-space:nowrap}.logout-btn:hover{background:var(--deep-brown);transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow-hover)}.logout-btn:active{transform:translateY(0)}.navbar-overlay{display:none}@media (max-width: 768px){.navbar-container{padding:var(--spacing-sm) var(--spacing-md)}.navbar-toggle{display:inline-block}.navbar-menu{position:absolute;top:calc(100% + 10px);right:var(--spacing-md);width:min(320px,calc(100vw - 2 * var(--spacing-md)));background:var(--cream);border:1px solid rgba(107,127,94,.18);border-radius:14px;box-shadow:0 18px 40px #0000001f;padding:.75rem;display:flex;flex-direction:column;align-items:stretch;gap:.35rem;opacity:0;transform:translateY(-6px);pointer-events:none;transition:var(--transition)}.navbar-menu.open{opacity:1;transform:translateY(0);pointer-events:auto}.navbar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0f0f0f40;opacity:0;pointer-events:none;transition:var(--transition);z-index:90}.navbar-overlay.show{opacity:1;pointer-events:auto}.nav-link{padding:.75rem .9rem;font-size:1rem;border-radius:12px}.nav-link:after{display:none}.navbar-user{margin-top:.35rem;padding-left:0;border-left:none;border-top:1px solid rgba(107,127,94,.18);padding-top:.6rem;display:flex;flex-direction:column;align-items:stretch;gap:.5rem}.user-name{display:block;font-size:.95rem;opacity:.9}.logout-btn{width:100%;padding:.75rem 1rem;border-radius:12px}@media (max-width: 380px){.logo-text{font-size:1.25rem}}}@media (min-width: 769px){.navbar-overlay{display:none!important}}body.dark-mode .navbar{background:#2a2a2a;border-bottom-color:#91b88533}body.dark-mode .navbar-menu{background:#2a2a2a;border-color:#91b88540}body.dark-mode .navbar-toggle{background:#2a2a2acc;border-color:#91b8854d}body.dark-mode .toggle-bar{background:var(--charcoal)}body.dark-mode .nav-link:hover{background:#e8775026}body.dark-mode .nav-link.active{background:#e8775033}body.dark-mode .navbar-user{border-left-color:#91b8854d;border-top-color:#91b8854d}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);position:relative;overflow:hidden}.login-container{background:#fff;padding:var(--spacing-xl) var(--spacing-lg);border-radius:20px;box-shadow:0 10px 40px var(--shadow);max-width:450px;width:100%;position:relative;z-index:2;animation:fadeIn .6s ease-out}.login-header{text-align:center;margin-bottom:var(--spacing-lg)}.header-icon{font-size:4rem;margin-bottom:var(--spacing-sm);animation:pulse 2s ease-in-out infinite}.login-header h1{margin-bottom:var(--spacing-xs);color:var(--deep-brown)}.subtitle{color:var(--olive);font-size:.95rem}.login-form{margin-bottom:var(--spacing-lg)}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;margin-bottom:var(--spacing-xs);font-weight:500;color:var(--deep-brown);font-size:.95rem}.form-group input{width:100%;padding:.875rem 1rem;border:2px solid var(--light-sage);border-radius:10px;font-size:1rem;transition:var(--transition);background:var(--warm-white)}.form-group input:focus{outline:none;border-color:var(--olive);background:#fff;box-shadow:0 0 0 3px #6b7f5e1a}.error-message{background:#e877501a;border:1px solid var(--burnt-orange);color:var(--deep-brown);padding:var(--spacing-sm);border-radius:8px;margin-bottom:var(--spacing-md);font-size:.9rem;animation:slideInLeft .3s ease-out}.hint{margin-top:var(--spacing-xs);font-size:.85rem;color:var(--olive);font-weight:500}.submit-btn{width:100%;padding:1rem;background:linear-gradient(135deg,var(--terracotta),var(--burnt-orange));color:#fff;border-radius:10px;font-weight:600;font-size:1rem;transition:var(--transition);box-shadow:0 4px 15px #d4765e4d}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #d4765e66}.submit-btn:active:not(:disabled){transform:translateY(0)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.divider{text-align:center;margin:var(--spacing-lg) 0;position:relative}.divider:before,.divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:var(--light-sage)}.divider:before{left:0}.divider:after{right:0}.divider span{background:#fff;padding:0 var(--spacing-sm);color:var(--olive);font-size:.9rem}.oauth-buttons{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.oauth-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem;border:2px solid var(--light-sage);border-radius:10px;font-weight:500;transition:var(--transition);background:#fff}.oauth-btn:hover:not(:disabled){border-color:var(--sage);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}.oauth-btn:disabled{opacity:.6;cursor:not-allowed}.login-footer{text-align:center;color:var(--olive);font-size:.95rem}.login-footer a{color:var(--terracotta);font-weight:600;transition:var(--transition)}.login-footer a:hover{color:var(--burnt-orange);text-decoration:underline}.decorative-bg{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;overflow:hidden;pointer-events:none}.circle{position:absolute;border-radius:50%;opacity:.15}.circle-1{width:400px;height:400px;background:var(--terracotta);top:-200px;right:-100px}.circle-2{width:300px;height:300px;background:var(--sage);bottom:-150px;left:-100px}.circle-3{width:200px;height:200px;background:var(--burnt-orange);top:50%;left:50%;transform:translate(-50%,-50%)}@media (max-width: 500px){.login-container{padding:var(--spacing-lg) var(--spacing-md)}.oauth-buttons{flex-direction:column}.circle-1,.circle-2{opacity:.08}}.register-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);position:relative;overflow:hidden}.register-container{background:#fff;padding:var(--spacing-xl) var(--spacing-lg);border-radius:20px;box-shadow:0 10px 40px var(--shadow);max-width:450px;width:100%;position:relative;z-index:2;animation:fadeIn .6s ease-out}.register-header{text-align:center;margin-bottom:var(--spacing-lg)}.register-header h1{margin-bottom:var(--spacing-xs);color:var(--deep-brown)}.register-form{margin-bottom:var(--spacing-lg)}@media (max-width: 500px){.register-container{padding:var(--spacing-lg) var(--spacing-md)}}body.dark-mode .register-page{background:linear-gradient(135deg,#1a1a1a,#2a2a2a)}body.dark-mode .register-container{background:#2a2a2a}body.dark-mode .form-group input{background:#1f1f1f;border-color:var(--light-sage);color:var(--charcoal)}body.dark-mode .oauth-btn{background:#1f1f1f;border-color:var(--light-sage)}body.dark-mode .circle{opacity:.05}.dashboard{min-height:calc(100vh - 70px);padding:var(--spacing-lg) 0;background:linear-gradient(135deg,var(--warm-white) 0%,var(--cream) 100%)}.dashboard-container{max-width:1000px;margin:0 auto;padding:0 var(--spacing-md)}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-lg);animation:fadeIn .6s ease-out}.header-content h1{margin-bottom:var(--spacing-xs);background:linear-gradient(135deg,var(--deep-brown),var(--terracotta));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-actions{display:flex;gap:var(--spacing-sm)}.edit-btn{padding:.75rem 1.5rem;background:#fff;color:var(--olive);border:2px solid var(--sage);border-radius:10px;font-weight:600;transition:var(--transition)}.edit-btn:hover{background:var(--sage);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #a8b5a04d}.edit-btn.active{background:var(--olive);color:#fff;border-color:var(--olive)}.clear-all-btn{padding:.75rem 1.5rem;background:#fff;color:var(--terracotta);border:2px solid var(--terracotta);border-radius:10px;font-weight:600;transition:var(--transition)}.clear-all-btn:hover{background:var(--terracotta);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #d4765e4d}.add-ingredient-section{background:#fff;padding:var(--spacing-lg);border-radius:16px;box-shadow:0 4px 20px var(--shadow);margin-bottom:var(--spacing-lg);animation:slideInLeft .6s ease-out}.add-ingredient-form{width:100%}.form-row{display:grid;grid-template-columns:2fr 1fr 1fr;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-field label{font-weight:500;color:var(--deep-brown);font-size:.9rem}.ingredient-input,.quantity-input,.unit-select{padding:.875rem 1rem;border:2px solid var(--light-sage);border-radius:12px;font-size:1rem;transition:var(--transition);background:var(--warm-white);font-family:var(--font-body)}.ingredient-input:focus,.quantity-input:focus,.unit-select:focus{outline:none;border-color:var(--olive);background:#fff;box-shadow:0 0 0 3px #6b7f5e1a}.unit-select{cursor:pointer}.add-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 2rem;background:linear-gradient(135deg,var(--olive),var(--sage));color:#fff;border-radius:12px;font-weight:600;font-size:1rem;transition:var(--transition);width:100%;box-shadow:0 4px 15px #6b7f5e4d}.add-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #6b7f5e66}.add-btn:disabled{opacity:.5;cursor:not-allowed}.add-icon{font-size:1.5rem;font-weight:300}.empty-state p{color:var(--olive);font-size:1.05rem}.ingredients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.ingredient-card{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:#fff;border:2px solid var(--cream);border-radius:12px;transition:var(--transition);animation:fadeIn .4s ease-out both}.ingredient-card:hover{border-color:var(--sage);transform:translateY(-3px);box-shadow:0 6px 20px var(--shadow)}.ingredient-card.edit-mode{border-color:var(--light-sage)}.ingredient-card.edit-mode:hover{border-color:var(--terracotta)}.ingredient-content{display:flex;align-items:center;gap:var(--spacing-sm);flex:1}.ingredient-icon{font-size:1.5rem;flex-shrink:0}.ingredient-info{display:flex;flex-direction:column;gap:.25rem}.ingredient-name{font-weight:600;color:var(--deep-brown);font-size:1.05rem}.ingredient-quantity{font-size:.9rem;color:var(--olive);font-weight:500}.remove-btn{width:32px;height:32px;border-radius:50%;background:#d4765e1a;color:var(--terracotta);font-size:1.5rem;display:flex;align-items:center;justify-content:center;transition:var(--transition);flex-shrink:0;opacity:1;animation:fadeIn .3s ease-out}.remove-btn:hover{background:var(--terracotta);color:#fff;transform:scale(1.1)}.actions-section{display:flex;flex-direction:column;gap:var(--spacing-md);animation:fadeIn .8s ease-out}.search-recipes-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:linear-gradient(135deg,var(--terracotta),var(--burnt-orange));color:#fff;border-radius:16px;font-weight:600;font-size:1.1rem;transition:var(--transition);box-shadow:0 4px 20px #d4765e4d;border:3px dashed rgba(255,255,255,.3)}.search-recipes-btn:hover{transform:translateY(-3px);box-shadow:0 6px 25px #d4765e80;border-color:#ffffff80}.search-icon{font-size:1.5rem}@media (max-width: 768px){.dashboard-header{flex-direction:column;gap:var(--spacing-md)}.header-actions{width:100%}.edit-btn,.clear-all-btn{flex:1}.form-row,.ingredients-grid{grid-template-columns:1fr}}.ingredient-card.editing{border-color:var(--olive);background:var(--warm-white);flex-direction:column;align-items:stretch}.ingredient-actions{display:flex;gap:.5rem}.edit-btn-small{width:32px;height:32px;border-radius:50%;background:#a8b5a026;color:var(--olive);font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:var(--transition);flex-shrink:0;border:none;cursor:pointer}.edit-btn-small:hover{background:var(--olive);transform:scale(1.1);filter:grayscale(0)}.edit-mode-content{width:100%;display:flex;flex-direction:column;gap:var(--spacing-sm)}.edit-fields{display:contents}.edit-input{padding:.5rem .75rem;border:2px solid var(--light-sage);border-radius:8px;font-size:.95rem;transition:var(--transition);background:#fff;font-family:var(--font-body)}.edit-input:focus{outline:none;border-color:var(--olive);box-shadow:0 0 0 3px #6b7f5e1a}.edit-actions{display:flex;gap:.5rem;justify-content:flex-end}.save-btn,.cancel-btn{padding:.5rem 1rem;border-radius:8px;font-weight:600;font-size:1.1rem;transition:var(--transition);border:none;cursor:pointer}.save-btn{background:var(--olive);color:#fff}.save-btn:hover:not(:disabled){background:var(--sage);transform:translateY(-1px)}.save-btn:disabled{opacity:.5;cursor:not-allowed}.cancel-btn{background:#d4765e1a;color:var(--terracotta)}.cancel-btn:hover{background:var(--terracotta);color:#fff;transform:translateY(-1px)}@media (max-width: 768px){.edit-fields{grid-template-columns:1fr}}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.spinner.small{width:14px;height:14px;border-width:2px}@keyframes spin{to{transform:rotate(360deg)}}.ingredient-card.deleting{opacity:.6;pointer-events:none}.error-banner{margin-bottom:12px;padding:10px 12px;border-radius:12px;background:#dc354514;border:1px solid rgba(220,53,69,.25);color:#b02a37;animation:slideInLeft .3s ease-out}input:disabled,select:disabled{opacity:.6;cursor:not-allowed}body.dark-mode .dashboard{background:linear-gradient(135deg,#1a1a1a,#2a2a2a)}body.dark-mode .add-ingredient-section,body.dark-mode .ingredient-card,body.dark-mode .empty-state{background:#2a2a2a}body.dark-mode .ingredient-input,body.dark-mode .quantity-input,body.dark-mode .unit-select,body.dark-mode .edit-input{background:#1f1f1f;border-color:var(--light-sage);color:var(--charcoal)}body.dark-mode .ingredient-card:hover{background:#333}body.dark-mode .error-banner{background:#e8775033;border-color:var(--burnt-orange);color:var(--burnt-orange)}.recipes-page{min-height:calc(100vh - 70px);padding:var(--spacing-lg) 0;background:linear-gradient(135deg,var(--warm-white) 0%,var(--cream) 100%)}.recipes-container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.recipes-header{margin-bottom:var(--spacing-lg);animation:fadeIn .6s ease-out}.back-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#fff;color:var(--olive);border:2px solid var(--sage);border-radius:10px;font-weight:600;font-size:.95rem;transition:var(--transition);margin-bottom:var(--spacing-md)}.recipes-header h1{margin-bottom:var(--spacing-xs);background:linear-gradient(135deg,var(--deep-brown),var(--terracotta));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-subtitle{color:var(--olive);font-size:1.1rem}.ingredients-summary-bar{background:#fff;padding:var(--spacing-md);border-radius:12px;box-shadow:0 2px 10px var(--shadow);margin-bottom:var(--spacing-lg);animation:slideInLeft .6s ease-out}.summary-info{display:flex;align-items:center;gap:var(--spacing-sm)}.summary-icon{font-size:1.75rem}.summary-text{font-weight:600;color:var(--deep-brown);font-size:1.05rem}.recipes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.recipe-card{position:relative;background:#fff;border-radius:16px;overflow:visible;box-shadow:0 4px 20px var(--shadow);transition:var(--transition);cursor:pointer;animation:fadeIn .5s ease-out both;padding:var(--spacing-lg)}.recipe-card:hover{transform:translateY(-8px);box-shadow:0 8px 30px var(--shadow-hover)}.recipe-content{padding-top:var(--spacing-sm)}.recipe-name{font-size:1.5rem;margin-bottom:var(--spacing-sm);color:var(--deep-brown)}.recipe-meta{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--cream)}.meta-item{display:flex;align-items:center;gap:.4rem;color:var(--olive);font-weight:500;font-size:.95rem}.meta-icon{font-size:1.1rem}.recipe-ingredients{margin-bottom:var(--spacing-md)}.ingredients-label{display:block;font-weight:600;color:var(--deep-brown);font-size:.9rem;margin-bottom:.5rem}.ingredients-tags{display:flex;flex-wrap:wrap;gap:.5rem}.ingredient-tag{padding:.4rem .75rem;background:var(--cream);color:var(--olive);border-radius:20px;font-size:.85rem;font-weight:500}.ingredient-tag.more{background:var(--sage);color:#fff}.view-recipe-btn{width:100%;padding:.875rem;background:linear-gradient(135deg,var(--olive),var(--sage));color:#fff;border-radius:10px;font-weight:600;transition:var(--transition);box-shadow:0 2px 8px #6b7f5e4d}.view-recipe-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #6b7f5e66}.empty-state{text-align:center;padding:var(--spacing-xl) var(--spacing-md);background:#fff;border-radius:16px;box-shadow:0 4px 20px var(--shadow);animation:fadeIn .8s ease-out}.empty-icon{font-size:5rem;margin-bottom:var(--spacing-md);opacity:.8}.empty-state h3{margin-bottom:var(--spacing-xs);color:var(--deep-brown)}.empty-state p{color:var(--olive);font-size:1.05rem;margin-bottom:var(--spacing-md)}.empty-action-btn{padding:1rem 2rem;background:linear-gradient(135deg,var(--terracotta),var(--burnt-orange));color:#fff;border-radius:10px;font-weight:600;transition:var(--transition);box-shadow:0 4px 15px #d4765e4d}.empty-action-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #d4765e66}@media (max-width: 768px){.recipes-grid{grid-template-columns:1fr}.recipe-card{max-width:100%}}body.dark-mode .recipes-page{background:linear-gradient(135deg,#1a1a1a,#2a2a2a)}body.dark-mode .ingredients-summary-bar,body.dark-mode .recipe-card{background:#2a2a2a}body.dark-mode .recipe-card:hover{background:#333}body.dark-mode .ingredient-tag{background:#1f1f1f;color:var(--sage)}body.dark-mode .ingredient-tag.more{background:var(--sage);color:#1f1f1f}.recipe-detail-page{min-height:calc(100vh - 70px);padding:var(--spacing-lg) 0;background:linear-gradient(135deg,var(--warm-white) 0%,var(--cream) 100%)}.recipe-detail-container{max-width:900px;margin:0 auto;padding:0 var(--spacing-md)}.back-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#fff;color:var(--olive);border:2px solid var(--sage);border-radius:10px;font-weight:600;font-size:.95rem;transition:var(--transition);margin-bottom:var(--spacing-lg);animation:fadeIn .6s ease-out}.back-btn:hover{background:var(--sage);color:#fff;transform:translate(-3px);box-shadow:0 4px 12px var(--shadow)}.recipe-header{background:#fff;padding:var(--spacing-lg);border-radius:16px;box-shadow:0 4px 20px var(--shadow);margin-bottom:var(--spacing-lg);animation:fadeIn .6s ease-out}.header-main{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-lg);gap:var(--spacing-md)}.header-main h1{flex:1;color:var(--deep-brown);font-size:2.5rem}.recipe-info-bar{display:flex;justify-content:space-between;gap:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--cream)}.info-item{display:flex;align-items:center;gap:var(--spacing-sm)}.info-icon{font-size:1.5rem;opacity:.8}.info-content{display:flex;flex-direction:column;gap:.1rem}.info-label{font-size:.8rem;color:var(--olive);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:1.1rem;font-weight:600;color:var(--deep-brown)}.recipe-main-content{display:grid;grid-template-columns:350px 1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.ingredients-section,.instructions-section{background:#fff;padding:var(--spacing-lg);border-radius:16px;box-shadow:0 4px 20px var(--shadow);animation:slideInLeft .7s ease-out}.ingredients-section h2,.instructions-section h2{font-size:1.5rem;margin-bottom:var(--spacing-md);color:var(--deep-brown);display:flex;align-items:center;gap:.5rem}.ingredients-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.ingredient-item{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--warm-white);border-radius:8px;transition:var(--transition)}.ingredient-item:hover{background:var(--cream);transform:translate(4px)}.ingredient-bullet{color:var(--terracotta);font-size:1.5rem;line-height:1;margin-top:-2px}.ingredient-text{display:flex;flex-direction:column;gap:.15rem;flex:1}.ingredient-text strong{color:var(--deep-brown);font-size:1rem}.ingredient-amount{color:var(--olive);font-size:.9rem;font-weight:500}.instructions-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.instruction-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--warm-white);border-radius:12px;transition:var(--transition)}.instruction-item:hover{background:var(--cream);transform:translate(4px);box-shadow:0 2px 8px var(--shadow)}.instruction-number{flex-shrink:0;width:36px;height:36px;background:linear-gradient(135deg,var(--olive),var(--sage));color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;box-shadow:0 2px 6px #6b7f5e4d}.instruction-text{flex:1;color:var(--charcoal);line-height:1.6;font-size:1rem}.tips-section{background:linear-gradient(135deg,#a8b5a026,#c8d5c026);padding:var(--spacing-lg);border-radius:16px;border:2px solid var(--sage);animation:fadeIn .8s ease-out}.tips-section h3{font-size:1.25rem;color:var(--deep-brown);margin-bottom:var(--spacing-sm);display:flex;align-items:center;gap:.5rem}.tips-section p{color:var(--charcoal);line-height:1.7;font-size:1rem;font-style:italic}@media (max-width: 768px){.recipe-main-content{grid-template-columns:1fr}.header-main{flex-direction:column;align-items:flex-start}.header-main h1{font-size:2rem}.recipe-info-bar{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.info-item{width:100%;border-right:none;justify-content:center!important}}.cook-btn{padding:.75rem 2rem;background:linear-gradient(135deg,var(--terracotta),var(--burnt-orange));color:#fff;border:none;border-radius:12px;font-weight:600;font-size:1rem;cursor:pointer;transition:var(--transition);box-shadow:0 4px 15px #d4765e4d;white-space:nowrap;flex-shrink:0}.cook-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #d4765e80}.cook-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.success-badge{padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--olive),var(--sage));color:#fff;border-radius:12px;font-weight:600;font-size:1rem;box-shadow:0 4px 15px #6b7f5e4d;animation:fadeIn .5s ease-out;white-space:nowrap;flex-shrink:0}.error-message{background:#e877501a;border:1px solid var(--burnt-orange);color:var(--deep-brown);padding:var(--spacing-sm) var(--spacing-md);border-radius:10px;margin-bottom:var(--spacing-md);font-size:.95rem;animation:slideInLeft .3s ease-out}@media (max-width: 768px){.header-main{flex-direction:column;align-items:stretch}.cook-btn,.success-badge{width:100%;justify-content:center}}body.dark-mode .recipe-detail-page{background:linear-gradient(135deg,#1a1a1a,#2a2a2a)}body.dark-mode .recipe-header,body.dark-mode .ingredients-section,body.dark-mode .instructions-section{background:#2a2a2a}body.dark-mode .back-btn{background:#2a2a2a;border-color:var(--sage)}body.dark-mode .ingredient-item,body.dark-mode .instruction-item{background:#1f1f1f}body.dark-mode .ingredient-item:hover,body.dark-mode .instruction-item:hover{background:#333}body.dark-mode .tips-section{background:linear-gradient(135deg,#7ba76f33,#91b88533);border-color:var(--sage)}body.dark-mode .error-message{background:#e8775033;border-color:var(--burnt-orange);color:var(--burnt-orange)}.settings{min-height:calc(100vh - 70px);padding:var(--spacing-lg) 0;background:linear-gradient(135deg,var(--warm-white) 0%,var(--cream) 100%)}.settings-container{max-width:800px;margin:0 auto;padding:0 var(--spacing-md)}.settings-header{margin-bottom:var(--spacing-lg);animation:fadeIn .6s ease-out}.settings-header h1{margin-bottom:var(--spacing-xs);background:linear-gradient(135deg,var(--deep-brown),var(--terracotta));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.settings-content{display:flex;flex-direction:column;gap:var(--spacing-lg)}.settings-section{background:#fff;padding:var(--spacing-lg);border-radius:16px;box-shadow:0 4px 20px var(--shadow);animation:slideInLeft .6s ease-out}.section-header{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--cream)}.section-header h2{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1.5rem;color:var(--deep-brown)}.settings-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.settings-form .form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.settings-form label{font-weight:500;color:var(--deep-brown);font-size:.95rem}.settings-form input{padding:.875rem 1rem;border:2px solid var(--light-sage);border-radius:10px;font-size:1rem;transition:var(--transition);background:var(--warm-white)}.settings-form input:focus{outline:none;border-color:var(--olive);background:#fff;box-shadow:0 0 0 3px #6b7f5e1a}.save-btn{padding:1rem 2rem;background:linear-gradient(135deg,var(--olive),var(--sage));color:#fff;border-radius:10px;font-weight:600;font-size:1rem;transition:var(--transition);align-self:flex-start;box-shadow:0 4px 15px #6b7f5e4d}.save-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6b7f5e66}.settings-options{display:flex;flex-direction:column;gap:var(--spacing-md)}.option-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:var(--warm-white);border-radius:12px;transition:var(--transition)}.option-item:hover{background:var(--cream)}.option-info h3{font-size:1.1rem;margin-bottom:.25rem;color:var(--deep-brown)}.option-info p{font-size:.9rem;color:var(--olive)}.toggle{position:relative;display:inline-block;width:56px;height:30px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:var(--light-sage);transition:var(--transition);border-radius:30px}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:4px;bottom:4px;background:#fff;transition:var(--transition);border-radius:50%;box-shadow:0 2px 4px #0003}.toggle input:checked+.toggle-slider{background:var(--olive)}.toggle input:checked+.toggle-slider:before{transform:translate(26px)}.language-select{padding:.75rem 1rem;border:2px solid var(--light-sage);border-radius:10px;font-size:1rem;font-family:var(--font-body);color:var(--deep-brown);background:#fff;cursor:pointer;transition:var(--transition);min-width:150px}.language-select:focus{outline:none;border-color:var(--olive);box-shadow:0 0 0 3px #6b7f5e1a}.account-actions{display:flex;flex-direction:column;gap:var(--spacing-sm)}.action-btn{padding:.875rem 1.5rem;border-radius:10px;font-weight:600;transition:var(--transition);text-align:left}.action-btn.secondary{background:var(--cream);color:var(--deep-brown);border:2px solid var(--sage)}.action-btn.secondary:hover{background:var(--sage);color:#fff;transform:translate(4px)}.action-btn.danger{background:#d4765e1a;color:var(--terracotta);border:2px solid var(--terracotta)}.action-btn.danger:hover{background:var(--terracotta);color:#fff;transform:translate(4px)}.info-section{background:linear-gradient(135deg,#a8b5a01a,#c8d5c01a);border:2px dashed var(--sage)}.app-info{display:flex;flex-direction:column;gap:var(--spacing-sm)}.info-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0}.info-label{color:var(--olive);font-weight:500}.info-value{color:var(--deep-brown);font-weight:600}@media (max-width: 768px){.option-item{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.toggle{align-self:flex-end}.language-select,.save-btn{width:100%}}body.dark-mode .settings{background:linear-gradient(135deg,#1a1a1a,#2a2a2a)}body.dark-mode .settings-section{background:#2a2a2a}body.dark-mode .settings-form input,body.dark-mode .language-select{background:#1f1f1f;border-color:var(--light-sage);color:var(--charcoal)}body.dark-mode .option-item{background:#1f1f1f}body.dark-mode .option-item:hover{background:#333}body.dark-mode .action-btn.secondary{background:#1f1f1f;border-color:var(--sage)}body.dark-mode .info-section{background:linear-gradient(135deg,#7ba76f26,#91b88526)}.app{min-height:100vh}:root{--cream: #FAF7F0;--warm-white: #FEFBF6;--sage: #A8B5A0;--olive: #6B7F5E;--terracotta: #D4765E;--burnt-orange: #E87750;--deep-brown: #3E2723;--charcoal: #2C2C2C;--light-sage: #C8D5C0;--shadow: rgba(62, 39, 35, .08);--shadow-hover: rgba(62, 39, 35, .15);--font-display: "Cormorant Garamond", serif;--font-body: "Karla", sans-serif;--spacing-xs: .5rem;--spacing-sm: 1rem;--spacing-md: 1.5rem;--spacing-lg: 2.5rem;--spacing-xl: 4rem;--transition: all .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: all .5s cubic-bezier(.4, 0, .2, 1)}body.dark-mode{--cream: #2a2a2a;--warm-white: #1f1f1f;--sage: #7BA76F;--olive: #91B885;--terracotta: #E87750;--burnt-orange: #FF9977;--deep-brown: #F5E6D3;--charcoal: #E8E8E8;--light-sage: #556B4F;--shadow: rgba(0, 0, 0, .4);--shadow-hover: rgba(0, 0, 0, .6)}body.dark-mode{background-color:#1a1a1a;color:#e8e8e8}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body);background-color:var(--warm-white);color:var(--charcoal);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s ease,color .3s ease}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:600;line-height:1.2;color:var(--deep-brown)}h1{font-size:3rem;font-weight:700}h2{font-size:2.25rem}h3{font-size:1.75rem}a{color:inherit;text-decoration:none}button{font-family:var(--font-body);cursor:pointer;border:none;background:none}input,textarea,select{font-family:var(--font-body);font-size:1rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.fade-in{animation:fadeIn .6s ease-out}.slide-in{animation:slideInLeft .5s ease-out}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--cream)}::-webkit-scrollbar-thumb{background:var(--sage);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--olive)}body.dark-mode .login-page{background:linear-gradient(135deg,#1a1a1a,#2a2a2a)}body.dark-mode .login-container{background:#2a2a2a;box-shadow:0 10px 40px #0009}body.dark-mode .form-group input,body.dark-mode .oauth-btn{background:#1f1f1f;border-color:var(--light-sage);color:var(--charcoal)}body.dark-mode .divider:before,body.dark-mode .divider:after{background:var(--light-sage)}body.dark-mode .divider span{background:#2a2a2a}body.dark-mode .circle{opacity:.08}
