@import"https://fonts.googleapis.com/css2?family=Outfit:wght@100..900&display=swap";:root{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;font-weight:400;color:#191919;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}a{font-weight:500;color:#056e00;text-decoration:none;transition:color .2s}a:hover{color:#045700;text-decoration:underline}body{margin:0;min-width:320px;min-height:100vh;background-color:#fff}h1{font-size:2em;line-height:1.2;font-weight:700;color:#191919}h2{font-size:1.5em;line-height:1.3;font-weight:600;color:#191919}h3{font-size:1.25em;line-height:1.4;font-weight:600;color:#191919}button{font-family:inherit;cursor:pointer}button:focus,button:focus-visible{outline:2px solid rgba(5,110,0,.5);outline-offset:2px}#root{width:100%;min-height:100vh;display:flex;align-items:flex-start;justify-content:center;margin:0;padding:0;text-align:left;background-color:#fff}h1{font-size:32px;font-weight:700;color:#191919;margin-bottom:24px}h2{font-size:24px;font-weight:600;color:#191919;margin-top:0;margin-bottom:20px}.app-header{display:flex;justify-content:space-between;align-items:center;padding:16px 0;background-color:#fff;margin-bottom:8px}.app-header h1{margin-bottom:0;font-size:24px;color:#056e00}.auth-container{flex-shrink:0}@media(max-width:768px){.app-header{padding:16px 0}.app-header h1{font-size:20px}}.app-container{padding:0 64px 80px;width:100%;max-width:1400px;background-color:#fff;position:relative;display:flex;flex-direction:column}@media(max-width:768px){.app-container{padding:0 24px 80px}}.create-container{display:flex;flex-direction:column;justify-content:center;min-height:calc(100vh - 200px)}@media(min-width:769px){.app-container{padding-bottom:120px}}.back-button{background-color:#056e00;border:none;color:#fff;font-size:20px;font-weight:700;cursor:pointer;padding:0;margin-bottom:24px;transition:opacity .2s ease;align-self:flex-start;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center}.back-button:hover{opacity:.8}.step-indicators{display:flex;gap:8px;justify-content:center;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.step-dot{width:6px;height:6px;border-radius:50%;background-color:#d1d5db;transition:background-color .3s ease}.step-dot.active{background-color:#056e00}.error-banner{margin:20px 0;padding:16px;background-color:#fef2f2;border:2px solid #ef4444;border-radius:12px;color:#991b1b;font-size:14px}.btn{padding:10px 16px;font-size:15px;font-weight:600;color:#fff;border:none;border-radius:24px;cursor:pointer;transition:background-color .2s ease;letter-spacing:.2px}.btn:hover{opacity:.9}.btn[data-loading=true]{background-color:#d1d5db;cursor:not-allowed;opacity:1}.btn-primary{background-color:#056e00}.btn-primary:not([data-loading=true]):hover{background-color:#045700}.btn-secondary{background-color:#4c6fff}.btn-secondary:not([data-loading=true]):hover{background-color:#3d5cef}.btn-success{background-color:#056e00}.btn-success:not([data-loading=true]):hover{background-color:#045700}.btn-warning{background-color:#4c6fff}.btn-warning:not([data-loading=true]):hover{background-color:#3d5cef}.btn-info{background-color:#c2185b}.btn-info:not([data-loading=true]):hover{background-color:#a31545}.btn-dark{background-color:#191919}.btn-dark:not([data-loading=true]):hover{background-color:#000}.ingredient-input-section{margin-bottom:32px;width:100%;max-width:600px;margin-left:auto;margin-right:auto}.add-direction-button{background:none;border:none;color:#6b7280;font-size:14px;cursor:pointer;padding:8px 0;margin:8px 0 16px;display:flex;align-items:center;gap:4px;transition:color .2s ease;font-family:inherit}.add-direction-button:hover{color:#374151}.label-text{margin-top:24px;margin-bottom:12px;margin-left:18px;font-weight:600;font-size:15px;color:#191919}.text-input{width:100%;padding:16px 18px;font-size:16px;border:2px solid #e5e7eb;border-radius:12px;margin-bottom:12px;transition:all .2s ease;font-family:inherit;background-color:#fafafa}.text-input:focus{outline:none;border-color:#056e00;background-color:#fff}.tag-input-container{display:flex;flex-wrap:wrap;align-content:flex-start;gap:6px;width:100%;padding:12px 18px;font-size:16px;border:1px solid #e5e7eb;border-radius:28px;margin-bottom:16px;background-color:#fafafa;transition:border-color .2s ease,background-color .2s ease;min-height:56px}.tag-input-container:focus-within{outline:none;border-color:#056e00;background-color:#fff}.ingredient-tag-inline{display:inline-flex;align-items:center;padding:0 12px;background-color:#e0e7fe;color:#3b82f6;font-size:14px;border-radius:6px;white-space:nowrap;height:32px;line-height:32px}.direction-tag-inline{display:inline-flex;align-items:center;padding:0 12px;background-color:#ede9fe;color:#7c3aed;font-size:14px;border-radius:6px;white-space:nowrap;height:32px;line-height:32px}.tag-input-field{flex:1;min-width:120px;border:none;outline:none;font-size:16px;background:transparent;font-family:inherit;padding:0;height:32px;line-height:32px}.text-input-field{width:100%;padding:14px;font-size:16px;border:2px solid #e5e7eb;border-radius:12px;margin-bottom:16px;background-color:#fafafa;transition:border-color .2s ease,background-color .2s ease;font-family:inherit;outline:none}.text-input-field:focus{border-color:#056e00;background-color:#fff}.dish-list-section{margin-top:32px;width:100%;max-width:600px;margin-left:auto;margin-right:auto}.dish-list{margin-top:24px;background-color:#fafafa;padding:24px;border-radius:16px;margin-bottom:20px;border:1px solid #e5e7eb}.dish-item{margin-bottom:12px;padding:8px 0}.dish-label{display:flex;align-items:center;cursor:pointer;transition:opacity .2s;position:relative}.dish-label:hover{opacity:.7}.dish-checkbox{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:24px;height:24px;min-width:24px;border:2px solid #d1d5db;border-radius:6px;margin-right:16px;cursor:pointer;background-color:#fff;transition:all .2s ease;position:relative}.dish-checkbox:hover{border-color:#9ca3af}.dish-checkbox:checked{background-color:#056e00;border-color:#056e00}.dish-checkbox:checked:after{content:"";position:absolute;left:7px;top:3px;width:6px;height:11px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.dish-name{color:#191919;font-size:15px;font-weight:500}.images-section{margin-top:32px;width:100%;max-width:600px;margin-left:auto;margin-right:auto}.images-hint{color:#6b7280;margin-bottom:20px;font-size:14px}.image-entry{margin-bottom:24px;padding:24px;background-color:#fafafa;border-radius:16px;border:1px solid #e5e7eb}.image-entry-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.image-entry-title{margin:0;color:#191919;font-size:18px;font-weight:600}.trash-button{background:none;border:none;cursor:pointer;padding:4px 8px;transition:color .2s ease;line-height:1;color:#6b7280;display:flex;align-items:center;justify-content:center}.trash-button:hover{color:#dc2626}.selected-badge{margin-left:12px;font-size:14px;font-weight:600;color:#056e00;background-color:#d1fae5;padding:4px 12px;border-radius:12px}.image-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.dish-image{width:100%;height:180px;object-fit:cover;border-radius:12px;border:2px solid #e5e7eb;cursor:pointer;transition:all .2s ease}.dish-image[data-selected=true]{border:4px solid #056e00}.dish-image[data-dimmed=true]{opacity:.4}.dish-image:hover:not([data-selected=true]){opacity:.8}.no-images{color:#9ca3af;font-style:italic;font-size:14px}.breakdown-section{margin-top:40px;width:100%;max-width:600px;margin-left:auto;margin-right:auto}.breakdown-card{background-color:#fff;padding:28px;border-radius:16px;margin-bottom:24px;border:1px solid #e5e7eb}.breakdown-image-container{margin-bottom:20px}.breakdown-image{width:100%;max-width:300px;height:240px;object-fit:cover;border-radius:12px;border:1px solid #e5e7eb;display:block}.breakdown-title{margin-top:0;margin-bottom:20px;color:#191919;font-size:22px;font-weight:700}.ingredient-section{margin-bottom:20px;padding:16px;background-color:#fafafa;border-radius:12px;border-left:4px solid}.action-link{margin-top:12px;font-size:14px;font-weight:600;background:none;border:none;padding:0;cursor:pointer;transition:opacity .2s ease;text-align:left}.action-link:hover{opacity:.7}.action-link[data-loading=true]{opacity:.5;cursor:not-allowed}.action-link.supporting{color:#4c6fff}.action-link.seasonings{color:#191919}.action-link.toppings{color:#c2185b}.section-label{display:block;margin-bottom:10px;font-weight:600;font-size:15px;text-transform:uppercase;letter-spacing:.5px}.section-label.core{color:#056e00}.ingredient-section.core{border-left-color:#056e00}.section-label.supporting{color:#4c6fff}.ingredient-section.supporting{border-left-color:#4c6fff}.section-label.seasonings{color:#191919}.ingredient-section.seasonings{border-left-color:#191919}.section-label.toppings{color:#c2185b}.ingredient-section.toppings{border-left-color:#c2185b}.ingredient-list{margin:0;padding-left:20px;color:#374151;font-size:15px;line-height:1.8}.ingredient-list li{margin-bottom:4px}.action-buttons{margin-top:24px;display:flex;gap:12px;flex-wrap:wrap}.action-buttons .btn{font-size:14px;padding:10px 20px}.recipe-accordion-section{margin-top:32px;width:100%;max-width:600px;margin-left:auto;margin-right:auto}.recipe-accordion-hint{color:#6b7280;margin-bottom:24px;font-size:14px}.accordion-root{display:flex;flex-direction:column;gap:12px;width:100%;max-width:800px;margin:0 auto}.accordion-item{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.accordion-item[data-state=open]{border-color:#056e00}.accordion-item.saved{background-color:#f0fdf4;border-color:#22c55e;animation:saveSuccess .5s ease-out}.accordion-item.saved .accordion-trigger{cursor:default;pointer-events:none}.accordion-item.saved .accordion-trigger:hover{background-color:transparent}.accordion-item.saved .accordion-title{color:#16a34a}.saved-badge{font-weight:500;font-size:14px;color:#16a34a}@keyframes saveSuccess{0%{transform:scale(1);background-color:#fff}50%{transform:scale(1.02);background-color:#dcfce7}to{transform:scale(1);background-color:#f0fdf4}}.view-saved-btn{margin-top:24px;width:100%}.accordion-header{margin:0}.accordion-trigger{width:100%;padding:20px 24px;display:flex;align-items:center;gap:12px;background:none;border:none;cursor:pointer;text-align:left;font-family:inherit;transition:background-color .2s ease}.accordion-trigger:hover{background-color:#fafafa}.accordion-title{font-size:18px;font-weight:600;color:#191919}.accordion-chevron{width:20px;height:20px;color:#6b7280;flex-shrink:0;transition:transform .2s ease}.accordion-trigger[data-state=open] .accordion-chevron{transform:rotate(90deg)}.accordion-content{overflow:hidden}.accordion-content[data-state=open]{animation:slideDown .2s ease-out}.accordion-content[data-state=closed]{animation:slideUp .2s ease-out}@keyframes slideDown{0%{height:0}to{height:var(--radix-accordion-content-height)}}@keyframes slideUp{0%{height:var(--radix-accordion-content-height)}to{height:0}}.accordion-body{padding:0 24px 24px}.accordion-ingredients{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.accordion-ingredient-section{padding:16px;background-color:#fafafa;border-radius:12px;border:2px solid}.accordion-ingredient-section:has(.accordion-label.core){border-color:#056e00}.accordion-ingredient-section:has(.accordion-label.supporting){border-color:#4c6fff}.accordion-ingredient-section:has(.accordion-label.seasonings){border-color:#191919}.accordion-ingredient-section:has(.accordion-label.toppings){border-color:#c2185b}.accordion-label{display:block;margin-bottom:8px;font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.accordion-label.core{color:#056e00}.accordion-label.supporting{color:#4c6fff}.accordion-label.seasonings{color:#191919}.accordion-label.toppings{color:#c2185b}.accordion-list{margin:0;padding-left:20px;color:#374151;font-size:14px;line-height:1.7}.accordion-list li{margin-bottom:2px}.accordion-actions{display:flex;flex-direction:column;gap:8px}.accordion-action-btn{width:100%}.btn-ghost{background-color:transparent;color:#6b7280;border:1px solid #d1d5db}.btn-ghost:hover{background-color:#f3f4f6;border-color:#9ca3af}.instructions-section{margin-top:40px;width:100%;max-width:600px;margin-left:auto;margin-right:auto}.instructions-section h2{text-align:center;margin-bottom:24px;font-size:28px;font-weight:700;color:#191919}.instructions-image-container{display:flex;justify-content:center;margin-bottom:32px}.instructions-image{width:100%;max-width:400px;height:280px;object-fit:cover;border-radius:16px;border:1px solid #e5e7eb}.instructions-content{background-color:#fafafa;padding:28px;border-radius:16px;border:1px solid #e5e7eb}.instructions-content h3{margin-top:0;margin-bottom:20px;font-size:18px;font-weight:600;color:#056e00}.instructions-list{margin:0;padding-left:24px;color:#374151;font-size:16px;line-height:1.8}.instructions-list li{margin-bottom:12px}.instructions-list li::marker{color:#056e00;font-weight:600}.instructions-loading{color:#6b7280;font-style:italic}.instructions-error{color:#ef4444}.recipe-detail{margin-top:32px;width:100%;max-width:600px;margin-left:auto;margin-right:auto}.recipe-detail-title{text-align:center;margin-bottom:24px;font-size:28px;font-weight:700!important;color:#191919}.recipe-title-prefix{font-size:14px;color:#9ca3af;font-weight:400}.recipe-detail-image-container{display:flex;justify-content:center;margin-top:24px;margin-bottom:24px}.recipe-detail-image{width:100%;max-width:400px;height:280px;object-fit:cover;border-radius:16px;border:1px solid #e5e7eb}.recipe-tabs{display:flex;background-color:#f3f4f6;border-radius:12px;padding:4px;width:fit-content;margin:0 auto 24px;gap:4px}.recipe-tab{padding:12px 48px;font-size:15px;font-weight:600;color:#6b7280;background:none;border:none;border-radius:10px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.recipe-tab:hover:not(.active){color:#374151}.recipe-tab.active{background-color:#fff;color:#056e00;box-shadow:0 1px 3px #0000001a}.recipe-tab:disabled{opacity:.5;cursor:not-allowed}.recipe-tab-content{min-height:300px}.ingredients-panel{display:flex;flex-direction:column;gap:16px}.ingredient-section-wrapper{margin-bottom:20px;width:100%;max-width:400px;margin-left:auto;margin-right:auto}.ingredient-category{padding:16px;background-color:#fafafa;border-radius:12px;border:2px solid}.ingredient-category-label{display:block;margin-bottom:8px;font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.ingredient-category-label.core{color:#056e00}.ingredient-category.core{border-color:#056e00}.ingredient-category-label.supporting{color:#4c6fff}.ingredient-category.supporting{border-color:#4c6fff}.ingredient-category-label.seasonings{color:#191919}.ingredient-category.seasonings{border-color:#191919}.ingredient-category-label.toppings{color:#c2185b}.ingredient-category.toppings{border-color:#c2185b}.suggest-more-btn{margin-top:12px;font-size:14px;font-weight:600;background:none;border:none;padding:0;cursor:pointer;transition:opacity .2s ease}.suggest-more-btn:hover:not(:disabled){opacity:.7}.suggest-more-btn:disabled{opacity:.5;cursor:not-allowed}.suggest-more-btn.supporting{color:#4c6fff}.suggest-more-btn.seasonings{color:#191919}.suggest-more-btn.toppings{color:#c2185b}.instructions-panel{display:flex;flex-direction:column;gap:20px;width:100%;max-width:400px;margin-left:auto;margin-right:auto}.instruction-mode-toggle{display:flex;border-bottom:2px solid #e5e7eb;margin-bottom:24px;width:fit-content;margin-left:auto;margin-right:auto}.mode-btn{padding:14px 24px;font-size:15px;font-weight:600;color:#6b7280;background:none;border:none;cursor:pointer;transition:all .2s ease;position:relative}.mode-btn:hover:not(.active){color:#191919}.mode-btn.active{color:#056e00}.mode-btn.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background-color:#056e00}.get-tips-btn{margin-top:24px;padding:12px 24px;font-size:14px;font-weight:600;color:#fff;background-color:#f59e0b;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s ease;align-self:flex-start}.get-tips-btn:hover:not(:disabled){background-color:#d97706}.get-tips-btn:disabled{background-color:#d1d5db;cursor:not-allowed}.tips-section{margin-top:28px;padding:16px;background-color:#fffbeb;border-radius:12px;border:2px solid #f59e0b}.tips-heading{margin:0 0 16px;font-size:16px;font-weight:700;color:#b45309;letter-spacing:.5px}.tips-list{margin:0;padding-left:20px;color:#78350f;font-size:15px;line-height:1.7}.tips-list li{margin-bottom:10px}.tips-list li:last-child{margin-bottom:0}@media(max-width:768px){.carousel-nav{width:40px;height:40px;font-size:20px}}.auth-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.auth-modal{background-color:#fff;border-radius:16px;padding:32px;max-width:400px;width:90%;position:relative;text-align:center}.auth-modal-close{position:absolute;top:12px;right:12px;background:none;border:none;cursor:pointer;color:#6b7280;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.auth-modal-close:hover{color:#191919}.auth-modal-title{margin:0 0 12px;font-size:20px;font-weight:700;color:#191919}.auth-modal-text{margin:0 0 24px;font-size:15px;color:#6b7280;line-height:1.5}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;background-color:#fff;border-top:1px solid #e5e7eb;padding:4px 0;padding-bottom:max(4px,env(safe-area-inset-bottom));z-index:100}@media(min-width:769px){.bottom-nav{bottom:32px}}.bottom-nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px;background:none;border:none;cursor:pointer;color:#6b7280;font-size:11px;font-weight:500;transition:color .2s ease}.bottom-nav-tab:hover{color:#374151}.bottom-nav-tab.active{color:#056e00}.library-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:24px;flex-wrap:wrap}.library-header h2{margin:0;flex-shrink:0}@media(max-width:768px){.library-header{gap:12px}}.library-header-actions{display:flex;align-items:center;gap:12px;flex-shrink:0}.library-sort-toggle{display:flex;gap:8px;background-color:#f3f4f6;padding:4px;border-radius:8px}.sort-btn{padding:8px;display:flex;align-items:center;justify-content:center;color:#6b7280;background:none;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.sort-btn:hover{color:#374151}.sort-btn.active{background-color:#fff;color:#056e00;box-shadow:0 1px 3px #0000001a}.library-menu-container{position:relative}.library-menu-btn{padding:8px;display:flex;align-items:center;justify-content:center;color:#6b7280;background:none;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.library-menu-btn:hover:not(:disabled){background-color:#f3f4f6;color:#374151}.library-menu-btn:disabled{opacity:.5;cursor:not-allowed}.library-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000;min-width:180px;overflow:hidden;animation:menuSlideDown .2s ease}@keyframes menuSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.library-menu-item{width:100%;padding:12px 16px;display:flex;align-items:center;gap:12px;font-size:14px;font-weight:500;color:#374151;background:none;border:none;cursor:pointer;transition:background-color .15s ease;text-align:left}.library-menu-item:hover{background-color:#f9fafb}.library-menu-item svg{flex-shrink:0}.library-edit-actions{display:flex;align-items:center;gap:12px}.library-selected-count{font-size:14px;font-weight:500;color:#374151}.library-delete-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:600;color:#fff;background-color:#dc2626;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.library-delete-btn:hover:not(:disabled){background-color:#b91c1c}.library-delete-btn:disabled{opacity:.5;cursor:not-allowed}.library-cancel-btn{padding:8px 16px;font-size:14px;font-weight:500;color:#6b7280;background-color:transparent;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;transition:all .2s ease}.library-cancel-btn:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af;color:#374151}.library-cancel-btn:disabled{opacity:.5;cursor:not-allowed}.library-search{position:relative;display:flex;align-items:center;flex:1;max-width:400px}@media(max-width:768px){.library-search{order:3;flex-basis:100%;max-width:none}}.library-search-icon{position:absolute;left:14px;color:#9ca3af;pointer-events:none}.library-search-input{width:100%;padding:12px 40px 12px 44px;font-size:15px;border:1px solid #e5e7eb;border-radius:10px;background-color:#f9fafb;transition:all .2s ease;font-family:inherit}.library-search-input:focus{outline:none;border-color:#056e00;background-color:#fff}.library-search-input::placeholder{color:#9ca3af}.library-search-clear{position:absolute;right:10px;background:none;border:none;color:#9ca3af;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.library-search-clear:hover{color:#6b7280;background-color:#e5e7eb}.library-content{display:flex;flex-direction:column;justify-content:center;min-height:calc(100vh - 200px)}.library-content:has(.library-grid){justify-content:flex-start;min-height:auto}.app-container h2{margin:0;font-size:24px;font-weight:500;color:#191919}.library-empty,.library-error{color:#6b7280;font-size:15px;text-align:center}.library-error{color:#dc2626}.skeleton-shimmer{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.skeleton-shimmer-yellow{background:linear-gradient(90deg,#fef3c7 25%,#fde68a,#fef3c7 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{border-radius:4px}.skeleton-image,.skeleton-tabs{background-color:#f0f0f0}.library-card.skeleton{cursor:default;pointer-events:none}.library-card.skeleton:hover{transform:none;box-shadow:0 1px 3px #0000000d}.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;align-items:start}@media(max-width:768px){.library-grid{grid-template-columns:repeat(2,1fr);gap:12px}}.library-card{display:flex;flex-direction:column;background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .2s ease;overflow:hidden;position:relative}.library-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.library-card.edit-mode{cursor:pointer}.library-card.selected{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f6}.library-card-checkbox{position:absolute;top:8px;left:8px;z-index:10}.checkbox{width:24px;height:24px;border-radius:50%;background-color:#0000004d;border:2px solid white;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.checkbox.checked{background-color:#3b82f6;border-color:#3b82f6}.library-card-badge{position:absolute;top:8px;left:8px;background-color:#056e00;color:#fff;font-size:10px;font-weight:700;padding:4px 10px;border-radius:12px;letter-spacing:.5px;z-index:10}.library-card-image{width:100%;aspect-ratio:1;object-fit:cover}.library-card-content{padding:12px;display:flex;flex-direction:column;gap:2px}.library-card-prefix{font-size:11px;color:#9ca3af;font-weight:400;line-height:1.2}.library-card-title{margin:0;font-size:16px;font-weight:600;color:#191919;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.6em}.library-card-status{margin:0;font-size:13px;color:#6b7280}.recipe-close-btn{background-color:#056e00;border:none;color:#fff;font-size:24px;font-weight:700;cursor:pointer;padding:0;margin-bottom:16px;display:inline-flex;align-items:center;justify-content:center;transition:opacity .2s ease;position:absolute;left:64px;width:32px;height:32px;border-radius:50%}.recipe-close-btn:hover{opacity:.8}@media(max-width:768px){.recipe-close-btn{position:static;margin-bottom:24px}}.recipe-grid-section{display:flex;flex-direction:column;gap:16px;padding:16px 0}.recipe-grid-section h2{margin:0;font-size:24px;font-weight:600;color:#191919}.recipe-grid-hint{margin:0;font-size:14px;color:#6b7280}.view-library-btn{margin-top:16px;align-self:center}.sign-in-banner{margin-top:24px;padding:24px;background:#f9fafb;border-radius:12px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px}.sign-in-banner p{margin:0;font-size:14px;color:#6b7280}.saving-recipes{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:64px 24px;text-align:center}.saving-recipes h2{margin:0;font-size:20px;font-weight:600;color:#191919}.saving-spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#056e00;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.recipe-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.recipe-modal{background:#fff;border-radius:16px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;position:relative}.recipe-modal-close{position:absolute;top:16px;right:16px;background:#fff;border:none;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;box-shadow:0 2px 8px #0000001a;transition:background .2s ease}.recipe-modal-close:hover{background:#f3f4f6}.recipe-modal-content{padding:24px}.app-footer-legal{position:fixed;bottom:0;left:0;right:0;padding:8px 0;background-color:#fafafa;border-top:1px solid #e5e7eb;display:flex;justify-content:center;align-items:center;gap:12px;z-index:40}@media(max-width:768px){.app-footer-legal{display:none}}.footer-legal-link{background:none;border:none;color:#9ca3af;font-size:12px;cursor:pointer;transition:color .2s ease;padding:2px 6px}.footer-legal-link:hover{color:#6b7280;text-decoration:underline}.footer-legal-separator{color:#d1d5db;font-size:12px}.user-dropdown-container{position:relative}.user-dropdown-trigger{display:flex;align-items:center;gap:8px;padding:6px 12px 6px 6px;background:none;border:1px solid #e5e7eb;border-radius:24px;cursor:pointer;transition:all .2s ease}.user-dropdown-trigger:hover{background-color:#f9fafb;border-color:#d1d5db}.user-dropdown-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}.user-dropdown-name{font-size:14px;font-weight:500;color:#374151}.user-dropdown-chevron{color:#6b7280;transition:transform .2s ease}.user-dropdown-chevron.open{transform:rotate(180deg)}.user-dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000;min-width:180px;overflow:hidden;animation:menuSlideDown .2s ease}.user-dropdown-item{width:100%;padding:12px 16px;display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:#374151;background:none;border:none;cursor:pointer;transition:background-color .15s ease;text-align:left}.user-dropdown-item:hover{background-color:#f9fafb}.user-dropdown-divider{height:1px;background-color:#e5e7eb;margin:4px 0}.legal-page{width:100%;min-height:100vh;background-color:#fff;padding:0 64px 80px;overflow-y:auto}@media(max-width:768px){.legal-page{padding:0 24px 80px}}.legal-content{max-width:800px;margin:0 auto;padding:40px 0}.legal-content h1{font-size:36px;font-weight:700;color:#191919;margin-bottom:8px}.legal-last-updated{font-size:14px;color:#6b7280;margin-bottom:32px}.legal-section{margin-bottom:32px}.legal-section h2{font-size:24px;font-weight:600;color:#191919;margin-bottom:16px;margin-top:32px}.legal-section h3{font-size:18px;font-weight:600;color:#374151;margin-bottom:12px;margin-top:20px}.legal-section p{font-size:15px;line-height:1.6;color:#374151;margin-bottom:12px}.legal-section ul{margin-left:24px;margin-bottom:16px}.legal-section li{font-size:15px;line-height:1.6;color:#374151;margin-bottom:8px}.legal-emphasis{font-weight:600;color:#191919}.legal-disclaimer{background-color:#f9fafb;border-left:4px solid #d97706;padding:16px;border-radius:4px}.legal-disclaimer p{margin-bottom:0}.legal-back-container{position:fixed;top:24px;left:64px;z-index:100}@media(max-width:768px){.legal-back-container{left:24px}}.legal-back-btn{background-color:#056e00;border:none;color:#fff;font-size:24px;font-weight:700;cursor:pointer;padding:0;transition:opacity .2s ease;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%}.legal-back-btn:hover{opacity:.8}
