*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #f59e0b;--primary-dark: #d97706;--background: #faf5f0;--surface: #ffffff;--text-primary: #1f2937;--text-secondary: #6b7280;--border: #e5e7eb}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(--background);color:var(--text-primary)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.app-container{display:flex;height:100vh;overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;overflow-y:auto}.content-area{flex:1;padding:2rem;max-width:1200px;margin:0 auto;width:100%}@media(max-width:768px){.app-container{flex-direction:column}.content-area{padding:1rem}}.sidebar{width:200px;background-color:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:1.5rem 1rem;overflow-y:auto}.sidebar-header{margin-bottom:2rem}.logo{display:flex;align-items:center;gap:.75rem;cursor:pointer}.logo-icon{font-size:1.75rem}.logo-text{font-size:1.25rem;font-weight:700;color:var(--primary)}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:.5rem;margin-bottom:2rem}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:.5rem;color:var(--text-secondary);text-decoration:none;transition:all .2s;font-weight:500}.nav-item:hover{background-color:var(--background);color:var(--text-primary)}.nav-item.active{background-color:var(--primary);color:#fff}.create-recipe-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.75rem 1rem;background-color:var(--primary);color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:background-color .2s;margin-bottom:1rem;text-decoration:none}.create-recipe-btn:hover{background-color:var(--primary-dark)}.sidebar-footer{padding-top:1rem;border-top:1px solid var(--border)}.user-menu-container{position:relative;margin-bottom:1rem}.user-menu-btn{width:100%;padding:.75rem;background-color:var(--background);border:1px solid var(--border);border-radius:.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:space-between}.user-menu-btn:hover{background-color:var(--surface);border-color:var(--primary)}.user-menu-info{display:flex;align-items:center;gap:.5rem;flex:1}.user-emoji{font-size:1.25rem}.user-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;margin-right:.5rem}.user-name{font-weight:500;color:var(--text-primary);font-size:.9rem}.chevron{color:var(--text-secondary);transition:transform .2s}.chevron.open{transform:rotate(180deg)}.user-dropdown{position:absolute;bottom:100%;left:0;right:0;margin-bottom:.5rem;background:var(--surface);border:1px solid var(--border);border-radius:.5rem;box-shadow:0 4px 12px #0000001a;overflow:hidden;z-index:10}.dropdown-item{width:100%;padding:.75rem 1rem;background:none;border:none;display:flex;align-items:center;gap:.75rem;color:var(--text-secondary);font-weight:500;cursor:pointer;transition:all .2s;text-align:left}.dropdown-item:hover{background:var(--background);color:var(--text-primary)}.dropdown-item.sign-out{border-top:1px solid var(--border);color:#ef4444}.dropdown-item.sign-out:hover{background:#fef2f2}.sign-out-btn{width:100%;padding:.5rem;background-color:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:.5rem;cursor:pointer;transition:all .2s;font-weight:500}.sign-out-btn:hover{background-color:var(--background);color:var(--text-primary)}@media(max-width:768px){.sidebar{width:100%;flex-direction:row;padding:1rem;border-bottom:1px solid var(--border);border-right:none}.sidebar-nav{flex-direction:row;flex:1;margin-bottom:0}.nav-item span,.create-recipe-btn span,.user-menu-btn .user-name{display:none}}.header{background-color:var(--surface);border-bottom:1px solid var(--border);padding:1rem 2rem}.header-content{display:flex;align-items:center;justify-content:flex-end;gap:1.5rem;max-width:1200px;margin:0 auto}.header-actions,.auth-links{display:flex;align-items:center;gap:1rem}.header-link{padding:.5rem 1rem;color:var(--text-secondary);text-decoration:none;font-weight:500;transition:color .2s}.header-link:hover{color:var(--text-primary)}.header-register-btn{padding:.5rem 1.5rem;background-color:var(--primary);color:#fff;text-decoration:none;font-weight:600;border-radius:.5rem;transition:background-color .2s}.header-register-btn:hover{background-color:var(--primary-dark)}.icon-btn{background:none;border:none;cursor:pointer;color:var(--text-secondary);transition:color .2s;position:relative;display:flex;align-items:center}.icon-btn:hover{color:var(--text-primary)}.notification-badge{position:absolute;top:-8px;right:-8px;background-color:var(--primary);color:#fff;font-size:.7rem;font-weight:700;padding:.25rem .4rem;border-radius:50%;min-width:18px;text-align:center}.profile-btn{width:36px;height:36px;border:2px solid var(--border);border-radius:50%;cursor:pointer;overflow:hidden;background:none;padding:0;transition:border-color .2s;display:block}.profile-btn:hover{border-color:var(--primary)}.profile-btn img{width:100%;height:100%;object-fit:cover}@media(max-width:768px){.header-content{justify-content:flex-end}.header-link{padding:.4rem .75rem;font-size:.9rem}.header-register-btn{padding:.4rem 1rem;font-size:.9rem}}.trending-card{position:relative;width:200px;height:250px;border-radius:1rem;overflow:hidden;cursor:pointer;flex-shrink:0;box-shadow:0 2px 8px #0000001a;transition:transform .2s}.trending-card:hover{transform:scale(1.05)}.card-image{width:100%;height:100%;object-fit:cover}.card-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);padding:1.5rem 1rem;display:flex;flex-direction:column;justify-content:flex-end;height:100%}.card-title{color:#fff;font-size:1rem;font-weight:700;margin-bottom:.25rem}.card-subtitle{color:#fffc;font-size:.85rem}@media(max-width:768px){.trending-card{width:160px;height:200px}}.trending-section{margin-bottom:3rem}.section-title{font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;color:var(--text-primary)}.carousel-container{position:relative;display:flex;align-items:center;gap:1rem}.carousel{display:flex;gap:1rem;overflow-x:hidden;scroll-behavior:smooth;flex:1}.carousel-btn{background-color:var(--surface);border:1px solid var(--border);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0;color:var(--text-primary)}.carousel-btn:hover{background-color:var(--primary);color:#fff;border-color:var(--primary)}.carousel-btn-left,.carousel-btn-right{position:relative}@media(max-width:768px){.carousel-btn{width:32px;height:32px}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-container{background:var(--surface);border-radius:1rem;box-shadow:0 20px 60px #00000026;max-width:420px;width:90%;overflow:hidden;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border)}.modal-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.modal-close-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;transition:color .2s}.modal-close-btn:hover{color:var(--text-primary)}.modal-body{padding:1.5rem}.modal-message{font-size:.95rem;color:var(--text-secondary);line-height:1.6;margin:0}.modal-footer{display:flex;gap:1rem;padding:1.5rem;border-top:1px solid var(--border);justify-content:flex-end}.modal-btn{padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;flex:1;max-width:150px}.modal-cancel-btn{background:var(--background);color:var(--text-primary);border:1px solid var(--border)}.modal-cancel-btn:hover{background:var(--border);border-color:var(--text-secondary)}.modal-confirm-btn{background:var(--primary);color:#fff}.modal-confirm-btn:hover{background:var(--primary-dark)}.modal-confirm-btn.dangerous{background:#ef4444}.modal-confirm-btn.dangerous:hover{background:#dc2626}@media(max-width:480px){.modal-container{width:85%}.modal-header,.modal-body{padding:1.25rem}.modal-footer{padding:1.25rem;flex-direction:column}.modal-btn{max-width:100%}}.recipe-card{background-color:var(--surface);border:1px solid var(--border);border-radius:1rem;overflow:hidden;box-shadow:0 1px 3px #0000000d;transition:box-shadow .2s}.recipe-card:hover{box-shadow:0 4px 12px #0000001a}.recipe-header{padding:1rem;border-bottom:1px solid var(--border)}.author-info{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:inherit;cursor:pointer;transition:opacity .2s}.author-info:hover{opacity:.8}.author-info:hover .author-name{color:var(--primary)}.author-emoji{font-size:1.5rem}.author-details{flex:1}.author-name{font-size:.95rem;font-weight:600;color:var(--text-primary);margin:0;transition:color .2s}.author-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}.recipe-meta{font-size:.8rem;color:var(--text-secondary);margin:.25rem 0 0}.recipe-image{width:100%;height:400px;object-fit:cover}.recipe-actions{display:flex;gap:.5rem;padding:1rem;border-bottom:1px solid var(--border)}.action-btn{background:none;border:none;cursor:pointer;color:var(--text-secondary);transition:color .2s;display:flex;align-items:center;gap:.25rem;font-size:.85rem;padding:0}.action-btn:hover{color:var(--text-primary)}.action-btn.liked{color:#ef4444}.action-btn.active,.action-btn.bookmarked{color:var(--primary)}.bookmark-btn{margin-left:auto}.comment-count{font-size:.85rem}.recipe-info{padding:1rem;display:flex;flex-direction:column}.likes-count{font-size:.9rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.recipe-title{display:block;opacity:1;visibility:visible;color:#111827!important}.recipe-description{font-size:.9rem;color:var(--text-secondary);margin:0;line-height:1.5}.comments-section{border-top:1px solid var(--border);padding:1rem}.comments-list{max-height:200px;overflow-y:auto;margin-bottom:1rem}.comment{margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.comment:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.comment-author{display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;color:inherit;margin-bottom:.25rem}.comment-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;margin-right:.5rem}.comment-author:hover .comment-name{color:var(--primary)}.comment-emoji{font-size:1rem}.comment-name{font-weight:600;font-size:.85rem;color:var(--text-primary);transition:color .2s}.comment-text{margin:.25rem 0 0 1.5rem;font-size:.9rem;color:var(--text-secondary);line-height:1.4}.comment-image{margin:.5rem 0 0 1.5rem;max-width:200px;max-height:150px;border-radius:.5rem;object-fit:cover}.add-comment{display:flex;flex-direction:column;gap:.75rem}.comment-image-preview{position:relative;display:inline-block;width:fit-content}.comment-image-preview img{max-width:150px;max-height:100px;border-radius:.5rem;object-fit:cover}.remove-image-btn{position:absolute;top:-8px;right:-8px;width:24px;height:24px;border-radius:50%;background:var(--text-primary);color:var(--surface);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center}.comment-input-row{display:flex;align-items:center;gap:.75rem}.image-upload-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--background);color:var(--text-secondary);cursor:pointer;transition:all .2s}.image-upload-btn:hover{background:var(--primary);color:#fff}.comment-input{flex:1;padding:.625rem .875rem;border:1px solid var(--border);border-radius:1.5rem;font-size:.9rem;background:var(--background);transition:all .2s}.send-comment-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;border:none;cursor:pointer;transition:all .2s}.send-comment-btn:hover:not(:disabled){background:var(--primary-dark)}.send-comment-btn:disabled{opacity:.5;cursor:not-allowed}.loading-comments,.no-comments,.login-prompt{padding:1rem;text-align:center;font-size:.9rem;color:var(--text-secondary)}.comment-delete-btn{background:transparent;border:none;padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#888;transition:color .2s ease,transform .1s ease}.comment-delete-btn:hover{color:#e53935;transform:scale(1.1)}.login-prompt p{margin:0}@media(max-width:768px){.recipe-image{height:300px}.recipe-header,.recipe-actions,.recipe-info,.comments-section{padding:.75rem}}.recipe-feed{margin-top:2rem}.recipes-list{display:flex;flex-direction:column;gap:2rem}@media(max-width:768px){.recipes-list{gap:1.5rem}}.search-bar-container{display:flex;gap:.75rem;align-items:flex-start;background:var(--surface);padding:1rem;border-radius:1rem;box-shadow:0 2px 8px #0000000d;margin-bottom:1.5rem}.search-mode-selector{position:relative}.mode-toggle{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--background);border:1px solid var(--border);border-radius:.5rem;color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.mode-toggle:hover{border-color:var(--primary)}.mode-dropdown{position:absolute;top:calc(100% + .5rem);left:0;background:var(--surface);border:1px solid var(--border);border-radius:.75rem;box-shadow:0 10px 30px #0000001a;z-index:100;overflow:hidden;min-width:220px}.mode-option{display:flex;flex-direction:column;align-items:flex-start;width:100%;padding:1rem;background:none;border:none;text-align:left;cursor:pointer;transition:background-color .2s;font-size:.95rem;font-weight:500;color:var(--text-primary)}.mode-option:hover{background:var(--background)}.mode-option.active{background:#f59e0b1a;color:var(--primary)}.mode-description{font-size:.8rem;font-weight:400;color:var(--text-secondary);margin-top:.25rem}.mode-option.active .mode-description{color:var(--primary-dark)}.search-input-wrapper{flex:1;display:flex;gap:.75rem;align-items:flex-start}.name-search{flex:1;position:relative;display:flex;align-items:center}.name-search .search-icon{position:absolute;left:1rem;color:var(--text-secondary);pointer-events:none}.name-search input{width:100%;padding:.75rem 2.5rem .75rem 2.75rem;border:1px solid var(--border);border-radius:.5rem;font-size:1rem;transition:all .2s}.name-search input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #f59e0b1a}.ingredient-search{flex:1;position:relative}.selected-ingredients{display:flex;flex-wrap:wrap;gap:.5rem;padding:.5rem;border:1px solid var(--border);border-radius:.5rem;min-height:48px;transition:all .2s;background:var(--surface)}.selected-ingredients:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #f59e0b1a}.ingredient-tag{display:flex;align-items:center;gap:.375rem;padding:.25rem .5rem .25rem .75rem;background:#f59e0b2e;color:var(--text-primary);border:1px solid var(--border);font-size:.875rem}.ingredient-tag button{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-primary)!important;opacity:.75;cursor:pointer;padding:0}.ingredient-tag button:hover{opacity:1}.ingredient-input{flex:1;min-width:150px;border:none!important;outline:none!important;padding:.25rem .5rem!important;font-size:.95rem;background:transparent}.ingredient-dropdown{position:absolute;top:calc(100% + .5rem);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:.75rem;box-shadow:0 10px 30px #0000001a;z-index:100;max-height:300px;overflow:hidden}.dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--border);font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.dropdown-header .count{background:var(--background);padding:.125rem .5rem;border-radius:1rem;font-size:.75rem}.ingredient-list{max-height:240px;overflow-y:auto;padding:.5rem}.ingredient-option{display:block;width:100%;padding:.625rem .75rem;background:none;border:none;border-radius:.375rem;text-align:left;font-size:.95rem;color:var(--text-primary);cursor:pointer;transition:background-color .2s}.ingredient-option:hover{background:var(--background)}.clear-btn{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.clear-btn:hover{background:var(--background);color:var(--text-primary)}.search-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--primary);color:#fff;border:none;border-radius:.5rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:background-color .2s;white-space:nowrap}.search-btn:hover{background:var(--primary-dark)}@media(max-width:768px){.search-bar-container{flex-direction:column}.search-mode-selector{width:100%}.mode-toggle{width:100%;justify-content:center}.mode-dropdown{width:100%}.search-input-wrapper{width:100%;flex-direction:column}.name-search,.ingredient-search{width:100%}.search-btn{width:100%;justify-content:center}}.discover-page{padding:1rem}.discover-header{margin-bottom:1.5rem}.discover-header h1{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}.discover-header p{color:var(--text-secondary);margin:0}.search-results-info{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--surface);border:1px solid var(--border);border-radius:.75rem;margin-bottom:1.5rem}.search-results-info p{margin:0;color:var(--text-primary)}.results-count{margin-left:.5rem;color:var(--text-secondary);font-size:.9rem}.clear-search-btn{padding:.5rem 1rem;background:transparent;border:1px solid var(--border);border-radius:.5rem;color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:all .2s}.clear-search-btn:hover{background:var(--background);color:var(--text-primary);border-color:var(--text-secondary)}.discover-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.no-results{text-align:center;padding:3rem;color:var(--text-secondary)}.no-results p{font-size:1.1rem}@media(max-width:768px){.discover-grid{grid-template-columns:1fr}.search-results-info{flex-direction:column;gap:1rem;text-align:center}}.profile-page{max-width:900px;margin:0 auto}.profile-header{background:var(--surface);border-radius:1rem;overflow:visible;margin-bottom:1.5rem;box-shadow:0 2px 8px #0000000d}.profile-info{padding:2rem;position:relative;display:flex;gap:2rem;align-items:flex-start}.avatar-section{position:relative;display:flex;flex-direction:column;align-items:center;flex-shrink:0}.profile-avatar{width:100px;height:100px;border-radius:50%;border:4px solid white;object-fit:cover;background:var(--background);box-shadow:0 2px 8px #0000001a}.edit-avatar-btn{position:absolute;bottom:8px;right:8px;width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;border:2px solid var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.edit-avatar-btn:hover{background:var(--primary-dark)}.profile-details{flex:1}.profile-name-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.profile-name{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.profile-username{font-size:.95rem;color:var(--text-secondary);margin:.25rem 0 0}.edit-profile-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid var(--border);border-radius:.5rem;background:var(--surface);color:var(--text-primary);font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s;text-decoration:none}.edit-profile-btn:hover{background:var(--background);border-color:var(--text-secondary)}.follow-btn{padding:.5rem 1.5rem;border:none;border-radius:.5rem;background:var(--primary);color:#fff;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s}.follow-btn:hover{background:var(--primary-dark)}.follow-btn.following{background:var(--surface);color:var(--text-primary);border:1px solid var(--border)}.follow-btn.following:hover{border-color:#ef4444;color:#ef4444;background:#fef2f2}.profile-bio{font-size:.95rem;color:var(--text-primary);line-height:1.6;margin:0 0 1rem}.profile-meta{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.meta-item{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:var(--text-secondary)}.meta-item.link{color:var(--primary);text-decoration:none}.meta-item.link:hover{text-decoration:underline}.profile-stats{display:flex;gap:2rem}.stat-item{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.stat-label{font-size:.8rem;color:var(--text-secondary)}.profile-tabs{display:flex;gap:.5rem;border-bottom:1px solid var(--border);margin-bottom:1.5rem}.tab-btn{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;background:none;border:none;color:var(--text-secondary);font-weight:500;font-size:.95rem;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.profile-recipes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.recipe-grid-item{position:relative;aspect-ratio:1;border-radius:.75rem;overflow:hidden;cursor:pointer}.recipe-grid-item img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.recipe-grid-item:hover img{transform:scale(1.05)}.recipe-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 50%);display:flex;flex-direction:column;justify-content:flex-end;padding:1rem;opacity:0;transition:opacity .3s}.recipe-grid-item:hover .recipe-overlay{opacity:1}.recipe-title{color:#fff;font-weight:600;font-size:.95rem;margin-bottom:.25rem}.recipe-likes{display:flex;align-items:center;gap:.375rem;color:#fff;font-size:.875rem}.recipe-delete-btn{position:absolute;top:.5rem;right:.5rem;width:36px;height:36px;border-radius:50%;background:#ef4444e6;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s;z-index:10}.recipe-grid-item:hover .recipe-delete-btn{opacity:1}.recipe-delete-btn:hover{background:#dc2626;transform:scale(1.1)}.recipe-delete-btn:active{transform:scale(.95)}.empty-state{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--text-secondary);text-align:center}.empty-state p{margin-top:1rem;font-size:1rem}@media(max-width:768px){.profile-info{flex-direction:column;align-items:center;text-align:center;padding:1.5rem 1rem}.avatar-section{margin-bottom:1rem}.profile-details{width:100%}.profile-name-row{flex-direction:column;align-items:center;justify-content:center}.profile-meta{flex-direction:column;gap:.5rem;justify-content:center}.profile-stats{justify-content:center;width:100%}.profile-recipes-grid{grid-template-columns:repeat(2,1fr)}}.create-recipe-page{max-width:800px;margin:0 auto}.create-recipe-header{margin-bottom:2rem}.create-recipe-header h1{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}.create-recipe-header p{color:var(--text-secondary);font-size:.95rem;margin:0}.recipe-form{display:flex;flex-direction:column;gap:2rem}.form-section{background:var(--surface);border-radius:1rem;padding:1.5rem;box-shadow:0 2px 8px #0000000d}.form-section h2{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.section-description{font-size:.875rem;color:var(--text-secondary);margin:-.75rem 0 1rem}.image-upload-section{margin-bottom:1.5rem}.image-upload{display:block;width:100%;aspect-ratio:16 / 9;border:2px dashed var(--border);border-radius:.75rem;cursor:pointer;overflow:hidden;transition:all .2s}.image-upload:hover{border-color:var(--primary);background:#f59e0b0d}.upload-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--text-secondary)}.upload-placeholder span{font-size:.95rem}.upload-hint{font-size:.8rem!important;color:var(--text-secondary)}.preview-image{width:100%;height:100%;object-fit:cover}.remove-image-btn{display:flex;align-items:center;gap:.375rem;margin-top:.75rem;padding:.5rem 1rem;background:none;border:1px solid var(--border);border-radius:.5rem;color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:all .2s}.remove-image-btn:hover{border-color:#ef4444;color:#ef4444;background:#fef2f2}.form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem}.form-group:last-child{margin-bottom:0}.form-group label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:var(--text-primary)}.form-group input,.form-group textarea,.form-group select{padding:.75rem 1rem;border:1px solid var(--border);border-radius:.5rem;font-size:1rem;transition:all .2s;background:var(--surface);font-family:inherit}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #f59e0b1a}.form-group input.error,.form-group textarea.error,.form-group select.error{border-color:#ef4444}.section-error{display:block;margin-bottom:1rem}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.form-row.three-cols{grid-template-columns:repeat(3,1fr)}.ingredients-list,.instructions-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.ingredient-row{display:grid;grid-template-columns:80px 120px 1fr auto;gap:.5rem;align-items:center}.ingredient-row input{padding:.625rem .75rem;border:1px solid var(--border);border-radius:.5rem;font-size:.95rem}.ingredient-row input:focus{outline:none;border-color:var(--primary)}.instruction-row{display:grid;grid-template-columns:auto 1fr auto;gap:.75rem;align-items:flex-start}.step-number{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;border-radius:50%;font-size:.875rem;font-weight:600;flex-shrink:0;margin-top:.5rem}.instruction-row textarea{padding:.625rem .75rem;border:1px solid var(--border);border-radius:.5rem;font-size:.95rem;resize:vertical;min-height:60px;font-family:inherit}.instruction-row textarea:focus{outline:none;border-color:var(--primary)}.remove-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--border);border-radius:.5rem;color:var(--text-secondary);cursor:pointer;transition:all .2s}.remove-btn:hover:not(:disabled){border-color:#ef4444;color:#ef4444;background:#fef2f2}.remove-btn:disabled{opacity:.4;cursor:not-allowed}.add-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.75rem;background:var(--background);border:1px dashed var(--border);border-radius:.5rem;color:var(--text-secondary);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.add-btn:hover{border-color:var(--primary);color:var(--primary);background:#f59e0b0d}.tags-input-container{border:1px solid var(--border);border-radius:.5rem;padding:.5rem;display:flex;flex-wrap:wrap;gap:.5rem;min-height:48px;transition:all .2s}.tags-input-container:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #f59e0b1a}.tags-list{display:flex;flex-wrap:wrap;gap:.5rem}.tag{display:flex;align-items:center;gap:.375rem;padding:.25rem .5rem .25rem .75rem;background:var(--primary);color:#fff;border-radius:1rem;font-size:.875rem}.tag button{display:flex;align-items:center;justify-content:center;background:none;border:none;color:#fff;opacity:.7;cursor:pointer;padding:0}.tag button:hover{opacity:1}.tag-input{flex:1;min-width:150px;border:none!important;outline:none!important;padding:.25rem .5rem!important;font-size:.95rem;box-shadow:none!important}.form-actions{display:flex;justify-content:flex-end;gap:1rem;padding:1rem 0}.cancel-btn{padding:.75rem 1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:.5rem;color:var(--text-primary);font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.cancel-btn:hover{background:var(--background);border-color:var(--text-secondary)}.submit-btn{padding:.75rem 2rem;background:var(--primary);border:none;border-radius:.5rem;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.submit-btn:hover:not(:disabled){background:var(--primary-dark)}.submit-btn:disabled{opacity:.7;cursor:not-allowed}@media(max-width:640px){.form-row,.form-row.three-cols{grid-template-columns:1fr}.ingredient-row{grid-template-columns:1fr 1fr;gap:.5rem}.ingredient-row .name-input{grid-column:1 / -1}.ingredient-row .remove-btn{position:absolute;right:0;top:0}.form-actions{flex-direction:column-reverse}.cancel-btn,.submit-btn{width:100%}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--background) 0%,#fff5eb 100%);padding:2rem}.auth-container{width:100%;max-width:420px;background:var(--surface);border-radius:1rem;padding:2.5rem;box-shadow:0 10px 40px #00000014}.back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-secondary);text-decoration:none;font-size:.875rem;margin-bottom:1.5rem;transition:color .2s}.back-link:hover{color:var(--primary)}.auth-header{text-align:center;margin-bottom:2rem}.auth-header.success{padding:1rem 0}.auth-logo{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1.5rem}.auth-logo .logo-icon{font-size:2rem}.auth-logo .logo-text{font-size:1.5rem;font-weight:700;color:var(--primary)}.auth-header h1{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.auth-header p{color:var(--text-secondary);font-size:.95rem}.success-icon{color:#22c55e;margin-bottom:1rem}.auth-form{display:flex;flex-direction:column;gap:1.25rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-secondary);pointer-events:none}.input-wrapper input{width:100%;padding:.875rem 1rem .875rem 2.75rem;border:1px solid var(--border);border-radius:.5rem;font-size:1rem;transition:all .2s;background:var(--surface)}.input-wrapper input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #f59e0b1a}.input-wrapper input.error{border-color:#ef4444}.password-toggle{position:absolute;right:1rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:0;display:flex;align-items:center}.password-toggle:hover{color:var(--text-primary)}.error-message{font-size:.8rem;color:#ef4444}.form-options{display:flex;align-items:center;justify-content:space-between}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary);cursor:pointer}.checkbox-label input[type=checkbox]{width:1rem;height:1rem;accent-color:var(--primary)}.checkbox-label.terms{font-size:.8rem}.checkbox-label.terms a{color:var(--primary);text-decoration:none}.checkbox-label.terms a:hover{text-decoration:underline}.forgot-link{font-size:.875rem;color:var(--primary);text-decoration:none;font-weight:500}.forgot-link:hover{text-decoration:underline}.auth-btn{width:100%;padding:.875rem;background:var(--primary);color:#fff;border:none;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s;margin-top:.5rem}.auth-btn:hover:not(:disabled){background:var(--primary-dark)}.auth-btn:disabled{opacity:.7;cursor:not-allowed}.auth-divider{display:flex;align-items:center;gap:1rem;margin:1.5rem 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-divider span{font-size:.8rem;color:var(--text-secondary)}.social-buttons{display:flex;gap:1rem}.social-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;border:1px solid var(--border);border-radius:.5rem;background:var(--surface);font-size:.875rem;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all .2s}.social-btn:hover{background:var(--background);border-color:var(--text-secondary)}.social-btn img{width:20px;height:20px}.auth-footer{text-align:center;margin-top:1.5rem;font-size:.875rem;color:var(--text-secondary)}.auth-footer a{color:var(--primary);text-decoration:none;font-weight:600}.auth-footer a:hover{text-decoration:underline}.success-actions{text-align:center;margin-top:2rem}.resend-text{font-size:.875rem;color:var(--text-secondary);margin-bottom:1.5rem}.resend-btn{background:none;border:none;color:var(--primary);font-weight:600;cursor:pointer}.resend-btn:hover{text-decoration:underline}.back-to-login{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-secondary);text-decoration:none;font-size:.875rem}.back-to-login:hover{color:var(--primary)}@media(max-width:480px){.auth-container{padding:1.5rem}.social-buttons{flex-direction:column}}.auth-container .input-wrapper{position:relative!important}.auth-container .input-wrapper svg.input-icon{position:absolute!important;left:1rem!important;top:50%!important;transform:translateY(-50%)!important;width:20px!important;height:20px!important;display:block!important;pointer-events:none!important;color:var(--text-secondary)!important}.auth-container .input-wrapper button.password-toggle{position:absolute!important;right:1rem!important;top:50%!important;transform:translateY(-50%)!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:0!important}.auth-container .input-wrapper input{padding-left:2.75rem!important}.recipe-detail-page{max-width:900px;margin:0 auto;padding:2rem}.recipe-detail-header{position:relative;width:100%;height:400px;border-radius:1rem;overflow:hidden;margin-bottom:2rem}.recipe-detail-image{width:100%;height:100%;object-fit:cover}.recipe-detail-overlay{position:absolute;bottom:0;left:0;right:0;padding:2rem;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);color:#fff}.recipe-detail-title{font-size:2.5rem;font-weight:700;margin:0 0 1rem;text-shadow:0 2px 4px rgba(0,0,0,.5)}.recipe-detail-author{display:flex;align-items:center;gap:.75rem}.author-emoji-large{font-size:2rem}.author-name-large{font-size:1.25rem;font-weight:600}.recipe-detail-content{background:var(--surface);border:1px solid var(--border);border-radius:1rem;padding:2rem}.recipe-detail-actions{display:flex;gap:1rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border);margin-bottom:1.5rem;flex-wrap:wrap}.detail-action-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--background);border:1px solid var(--border);border-radius:.5rem;color:var(--text-secondary);cursor:pointer;transition:all .2s;font-weight:500}.detail-action-btn:hover{background:var(--surface);color:var(--text-primary);border-color:var(--primary)}.detail-action-btn.liked{color:#ef4444;border-color:#ef4444}.detail-action-btn.bookmarked{color:var(--primary);border-color:var(--primary)}.detail-action-btn.active{background:var(--background);border-color:#eb980a;color:#eb980a}.detail-action-btn.active svg{color:#eb980a}.detail-action-btn.active:hover{background:var(--background);border-color:#d97706;color:#d97706}.detail-action-btn.active:hover svg{color:#d97706}.recipe-meta-info{display:flex;gap:2rem;padding:1.5rem 0;border-bottom:1px solid var(--border);margin-bottom:2rem;flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-weight:500}.meta-item svg{color:var(--primary)}.recipe-section{margin-bottom:2.5rem}.recipe-section:last-child{margin-bottom:0}.recipe-section h2{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0 0 1.5rem}.recipe-full-description{font-size:1.1rem;line-height:1.8;color:var(--text-secondary);margin:0}.ingredients-list{list-style:none;padding:0;margin:0;display:grid;gap:.75rem}.ingredient-item{display:flex;gap:1rem;padding:1rem;background:var(--background);border-radius:.5rem;border:1px solid var(--border)}.ingredient-amount{font-weight:600;color:var(--primary);min-width:100px}.ingredient-name{color:var(--text-primary)}.instructions-list{list-style:none;padding:0;margin:0;counter-reset:step-counter}.instruction-item{display:flex;gap:1.5rem;margin-bottom:1.5rem;padding:1.5rem;background:var(--background);border-radius:.5rem;border:1px solid var(--border);counter-increment:step-counter}.instruction-item:last-child{margin-bottom:0}.instruction-number{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;border-radius:50%;font-weight:700;font-size:1.1rem}.instruction-number:before{content:counter(step-counter)}.instruction-text{margin:0;color:var(--text-primary);line-height:1.6;font-size:1.05rem}.comments-section{border-top:2px solid var(--border);padding-top:2rem}.comment-form{display:flex;gap:1rem;margin-bottom:2rem;padding:1rem;background:var(--background);border-radius:.75rem;border:1px solid var(--border)}.comment-input{flex:1;padding:.75rem 1rem;border:1px solid var(--border);border-radius:.5rem;font-size:1rem;color:var(--text-primary);background:var(--surface);transition:border-color .2s}.comment-input:focus{outline:none;border-color:var(--primary)}.comment-submit-btn{padding:.75rem 1rem;background:var(--primary);color:#fff;border:none;border-radius:.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.comment-submit-btn:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px)}.comment-submit-btn:disabled{opacity:.5;cursor:not-allowed}.comments-list{display:flex;flex-direction:column;gap:1rem}.comment-item{display:flex;gap:1rem;padding:1rem;background:var(--background);border-radius:.75rem;border:1px solid var(--border);transition:all .2s}.comment-item:hover{border-color:var(--primary);box-shadow:0 2px 8px #e412121a}.comment-avatar{flex-shrink:0;width:40px;height:40px;background:var(--surface);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;border:2px solid var(--border)}.comment-content{flex:1;min-width:0}.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.comment-author{font-weight:600;color:var(--text-primary)}.comment-timestamp{font-size:.875rem;color:var(--text-secondary)}.comment-text{margin:0;color:var(--text-primary);line-height:1.5;word-wrap:break-word}.comments-section-detail{border-top:2px solid var(--border);padding-top:2rem;margin-top:2rem}.comments-section-detail h3{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 1.5rem}.comments-section-detail .comments-list{max-height:400px;overflow-y:auto;margin-bottom:1.5rem;display:flex;flex-direction:column;gap:1rem}.comments-section-detail .comment{padding:1rem;background:var(--background);border-radius:.75rem;border:1px solid var(--border)}.comments-section-detail .comment-author{display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;color:inherit;margin-bottom:.5rem}.comments-section-detail .comment-author:hover .comment-name{color:var(--primary)}.comments-section-detail .comment-name{font-weight:600;font-size:1rem;color:var(--text-primary);transition:color .2s}.comments-section-detail .comment-text{margin:.5rem 0 0 2rem;font-size:1rem;color:var(--text-secondary);line-height:1.6}.comments-section-detail .comment-image{margin:.75rem 0 0 2rem;max-width:300px;max-height:200px;border-radius:.75rem;object-fit:cover;border:1px solid var(--border)}.comments-section-detail .add-comment{display:flex;flex-direction:column;gap:.75rem}.comments-section-detail .comment-image-preview{position:relative;display:inline-block;width:fit-content}.comments-section-detail .comment-image-preview img{max-width:200px;max-height:150px;border-radius:.75rem;object-fit:cover;border:1px solid var(--border)}.comments-section-detail .remove-image-btn{position:absolute;top:-8px;right:-8px;width:28px;height:28px;border-radius:50%;background:var(--text-primary);color:var(--surface);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003}.comments-section-detail .comment-input-row{display:flex;align-items:center;gap:.75rem}.comments-section-detail .image-upload-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--background);color:var(--text-secondary);cursor:pointer;transition:all .2s;border:1px solid var(--border)}.comments-section-detail .image-upload-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.comments-section-detail .comment-input{flex:1;padding:.75rem 1rem;border:1px solid var(--border);border-radius:1.5rem;font-size:1rem;background:var(--background);transition:all .2s}.comments-section-detail .comment-input:focus{outline:none;border-color:var(--primary)}.comments-section-detail .send-comment-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--primary);color:#fff;border:none;cursor:pointer;transition:all .2s}.comments-section-detail .send-comment-btn:hover:not(:disabled){background:var(--primary-dark);transform:scale(1.05)}.comments-section-detail .send-comment-btn:disabled{opacity:.5;cursor:not-allowed}.comments-section-detail .loading-comments,.comments-section-detail .no-comments{padding:2rem;text-align:center;font-size:1rem;color:var(--text-secondary)}.comments-section-detail .login-prompt{padding:1.5rem;text-align:center;background:var(--background);border-radius:.75rem;border:1px solid var(--border)}.comments-section-detail .login-prompt p{margin:0;font-size:1rem;color:var(--text-secondary)}.author-avatar-large{width:100px;height:100px;border-radius:50%;object-fit:cover;margin-right:.5rem}.detail-action-btn.edit-btn,.detail-action-btn.delete-btn{border-color:transparent!important}.detail-action-btn.edit-btn{color:#3b82f6}.detail-action-btn.edit-btn:hover{background:#eff6ff;color:#1d4ed8;border-color:#1d4ed8!important}.detail-action-btn.edit-btn:active{border-color:#1d4ed8!important}.detail-action-btn.delete-btn{color:#ef4444}.detail-action-btn.delete-btn:hover:not(:disabled){background:#fef2f2;color:#dc2626;border-color:#dc2626!important}.detail-action-btn.delete-btn:active{border-color:#dc2626!important}.detail-action-btn:disabled{opacity:.6;cursor:not-allowed}.comment-delete-btn{background:none;border:none;color:#ef4444;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.comment-delete-btn:hover{background:#fef2f2;color:#dc2626}.comment-delete-btn:active{transform:scale(.95)}@media(max-width:768px){.recipe-detail-page{padding:1rem}.recipe-detail-header{height:300px}.recipe-detail-title{font-size:1.75rem}.recipe-detail-content{padding:1.5rem}.recipe-detail-actions{gap:.5rem}.detail-action-btn{padding:.5rem 1rem;font-size:.9rem}.recipe-meta-info{gap:1rem}.comment-form{padding:.75rem}.comment-input{font-size:.9rem}.comment-avatar{width:36px;height:36px;font-size:1.25rem}.comments-section-detail h3{font-size:1.25rem}.comments-section-detail .comments-list{max-height:300px}.comments-section-detail .comment-text{margin-left:1.5rem;font-size:.9rem}.comments-section-detail .comment-image{margin-left:1.5rem;max-width:200px;max-height:150px}.comments-section-detail .image-upload-btn,.comments-section-detail .send-comment-btn{width:36px;height:36px}}.edit-recipe-page{min-height:100vh;padding:2rem;background:var(--background)}.edit-recipe-container{max-width:700px;margin:0 auto;background:var(--surface);border-radius:1rem;padding:2rem;box-shadow:0 2px 8px #0000000d}.edit-recipe-container h1{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0 0 2rem}.back-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:.5rem;color:var(--text-primary);cursor:pointer;font-weight:500;transition:all .2s;margin-bottom:2rem}.back-btn:hover{background:var(--background);border-color:var(--primary);color:var(--primary)}.error-message{padding:1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;margin-bottom:1.5rem}.success-message{padding:1rem;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:.5rem;color:#16a34a;margin-bottom:1.5rem}.edit-recipe-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:var(--text-primary);font-size:.95rem}.form-group input,.form-group textarea{padding:.75rem 1rem;border:1px solid var(--border);border-radius:.5rem;font-size:1rem;color:var(--text-primary);background:var(--background);transition:all .2s;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.form-group textarea{resize:vertical;min-height:100px}.image-preview{margin-top:1rem;border-radius:.5rem;overflow:hidden;border:1px solid var(--border)}.image-preview img{width:100%;height:auto;max-height:300px;object-fit:cover}.time-fields{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.ingredients-input{display:flex;gap:.5rem;margin-bottom:1rem}.ingredients-input input{flex:1;padding:.75rem 1rem;border:1px solid var(--border);border-radius:.5rem;font-size:.95rem;background:var(--background)}.ingredients-input input:focus{outline:none;border-color:var(--primary)}.add-ingredient-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:var(--primary);color:#fff;border:none;border-radius:.5rem;cursor:pointer;transition:all .2s}.add-ingredient-btn:hover{background:var(--primary-dark);transform:translateY(-1px)}.add-ingredient-btn:active{transform:translateY(0)}.ingredients-list{display:flex;flex-direction:column;gap:.5rem}.ingredient-tag{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--background);border:1px solid var(--border);border-radius:.5rem;transition:all .2s}.ingredient-tag:hover{border-color:var(--primary);background:#3b82f60d}.ingredient-info{display:flex;align-items:center;gap:.75rem;flex:1}.ingredient-quantity{font-weight:600;color:var(--primary);min-width:80px;font-size:.9rem}.ingredient-name{color:var(--text-primary);font-size:.95rem}.remove-ingredient-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:#fef2f2;color:#ef4444;border:none;border-radius:.375rem;cursor:pointer;transition:all .2s}.remove-ingredient-btn:hover{background:#ef4444;color:#fff}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem;padding-top:1.5rem;border-top:1px solid var(--border)}.cancel-btn,.submit-btn{padding:.75rem 1.5rem;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s;border:none;font-size:1rem}.cancel-btn{background:var(--background);color:var(--text-primary);border:1px solid var(--border)}.cancel-btn:hover{background:var(--border)}.submit-btn{background:var(--primary);color:#fff;min-width:150px}.submit-btn:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.submit-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.edit-recipe-page{padding:1rem}.edit-recipe-container{padding:1.5rem}.edit-recipe-container h1{font-size:1.5rem}.time-fields{grid-template-columns:1fr}.ingredients-input{flex-direction:column}.add-ingredient-btn{width:100%}.form-actions{flex-direction:column}.cancel-btn,.submit-btn{width:100%}}.edit-profile-page{max-width:800px;margin:0 auto;padding:20px}.edit-profile-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid #e5e7eb}.edit-profile-header h1{font-size:24px;font-weight:600;color:#111827;flex:1;text-align:center}.back-btn{display:flex;align-items:center;gap:8px;background:none;border:none;color:#6b7280;font-size:14px;cursor:pointer;padding:8px 12px;border-radius:8px;transition:background-color .2s}.back-btn:hover{background-color:#f3f4f6}.save-btn{background-color:#10b981;color:#fff;border:none;padding:8px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.save-btn:hover{background-color:#059669}.edit-profile-form{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.image-uploads{position:relative;margin-bottom:40px;display:flex;justify-content:center;padding:40px 20px 20px}.avatar-section{position:relative;display:inline-block}.avatar-preview{width:140px;height:140px;border-radius:50%;border:4px solid #f3f4f6;object-fit:cover;display:block;background:#f3f4f6;box-shadow:0 2px 8px #0000001a}.upload-avatar-btn{position:absolute;bottom:8px;right:8px;width:40px;height:40px;border-radius:50%;background-color:#10b981;color:#fff;border:2px solid white;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #0000001a}.upload-avatar-btn:hover{background-color:#059669;transform:scale(1.1)}.upload-avatar-btn:active{transform:scale(.95)}.form-fields{padding:20px 30px 30px}.form-group{margin-bottom:20px;position:relative}.form-group label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:8px}.form-group input,.form-group textarea{width:100%;padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;color:#111827;transition:border-color .2s;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#10b981}.form-group textarea{resize:vertical;min-height:100px;font-family:inherit}.char-count{position:absolute;bottom:-20px;right:0;font-size:12px;color:#6b7280}@media(max-width:768px){.edit-profile-page{padding:10px}.edit-profile-header h1{font-size:20px}.image-uploads{padding:30px 20px 10px}.avatar-preview{width:120px;height:120px}.upload-avatar-btn{width:36px;height:36px}.form-fields{padding:15px 20px 20px}}.chat-page-container{display:flex;flex-direction:column;height:100vh;background:linear-gradient(135deg,#f5f5f5,#fafafa);overflow:hidden}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 2px 8px #0000000d}.chat-header-content h1{margin:0;font-size:28px;font-weight:600;color:#1f2937}.chat-header-content p{margin:8px 0 0;font-size:14px;color:#6b7280}.clear-chat-btn{padding:10px 20px;background-color:#ef4444;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.clear-chat-btn:hover:not(:disabled){background-color:#dc2626;transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.clear-chat-btn:disabled{background-color:#9ca3af;cursor:not-allowed;opacity:.6}.chat-messages-container{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:#6b7280}.empty-state-icon{font-size:64px;margin-bottom:16px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.empty-state h2{margin:0 0 8px;font-size:24px;color:#374151;font-weight:600}.empty-state p{margin:0;font-size:16px;color:#9ca3af}.chat-messages{display:flex;flex-direction:column;gap:16px}.message{display:flex;gap:12px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{justify-content:flex-end}.message.user .message-avatar{order:2}.message.user .message-content{order:1}.message-avatar{display:flex;align-items:flex-end;font-size:24px;height:40px;width:40px;flex-shrink:0}.avatar-user{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background-color:#3b82f6;border-radius:50%;font-size:18px}.avatar-assistant{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background-color:#10b981;border-radius:50%;font-size:18px}.message-content{max-width:600px;display:flex;align-items:flex-end}.message-content p{margin:0;padding:12px 16px;border-radius:12px;line-height:1.5;word-break:break-word;font-size:15px}.message.assistant .message-content p{background-color:#e5e7eb;color:#1f2937}.message.user .message-content p{background-color:#3b82f6;color:#fff}.typing-indicator{display:flex;gap:4px;padding:12px 16px;background-color:#e5e7eb;border-radius:12px}.typing-indicator span{width:8px;height:8px;background-color:#6b7280;border-radius:50%;animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-8px)}}.error-message{padding:12px 16px;background-color:#fee2e2;border-left:4px solid #ef4444;border-radius:6px;color:#7f1d1d;margin-top:12px;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.error-message p{margin:0;font-size:14px}.chat-input-form{padding:20px;background:#fff;border-top:1px solid #e5e7eb;box-shadow:0 -2px 8px #0000000d}.input-wrapper{display:flex;gap:12px;align-items:center;max-width:900px;margin:0 auto;width:100%}.chat-input{flex:1;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:15px;font-family:inherit;transition:all .3s ease;outline:none}.chat-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.chat-input:disabled{background-color:#f3f4f6;color:#9ca3af;cursor:not-allowed}.send-btn{width:44px;height:44px;border:none;background-color:#3b82f6;color:#fff;border-radius:8px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;flex-shrink:0}.send-btn:hover:not(:disabled){background-color:#2563eb;transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.send-btn:disabled{background-color:#9ca3af;cursor:not-allowed;opacity:.6}.chat-messages-container::-webkit-scrollbar{width:8px}.chat-messages-container::-webkit-scrollbar-track{background:transparent}.chat-messages-container::-webkit-scrollbar-thumb{background-color:#d1d5db;border-radius:4px;border:2px solid transparent;background-clip:content-box}.chat-messages-container::-webkit-scrollbar-thumb:hover{background-color:#9ca3af;background-clip:content-box}@media(max-width:768px){.chat-page-container{height:calc(100vh - 60px)}.chat-header{padding:16px 20px;flex-wrap:wrap;gap:12px}.chat-header-content h1{font-size:20px}.chat-header-content p{display:none}.chat-messages-container{padding:12px}.message-content{max-width:90vw}.chat-input-form{padding:12px}.input-wrapper{gap:8px}.chat-input{padding:10px 12px;font-size:14px}.send-btn{width:40px;height:40px;font-size:16px}}
