:root{--bg-primary:#f5f5f5;--bg-card:#fff;--bg-card-alt:#fafafa;--bg-card-hover:#f9f9f9;--bg-input:#fff;--bg-toolbar:#f9f9f9;--text-primary:#333;--text-secondary:#666;--text-muted:#999;--text-faint:#888;--border:#eee;--border-strong:#ddd;--border-faint:#f0f0f0;--accent:#ff6b6b;--accent-hover:#ff5252;--accent-light:hsla(0,100%,71%,.1);--green:#4caf50;--green-hover:#45a049;--shadow-sm:0 1px 4px rgba(0,0,0,.08);--shadow-md:0 2px 8px rgba(0,0,0,.1);--shadow-lg:0 4px 12px rgba(0,0,0,.12);--modal-overlay:rgba(0,0,0,.5);--tag-cuisine-bg:#e3f2fd;--tag-cuisine-color:#1565c0;--tag-meal-bg:#f3e5f5;--tag-meal-color:#7b1fa2;--difficulty-easy-bg:#c8e6c9;--difficulty-easy-color:#2e7d32;--difficulty-medium-bg:#ffe0b2;--difficulty-medium-color:#e65100;--difficulty-hard-bg:#ffcdd2;--difficulty-hard-color:#c62828;--error-bg:#ffe5e5;--error-color:#d32f2f;--error-border:#d32f2f;--fav-hover-bg:#fff0f0;--fav-color:#e53935;--equip-bg:#eceff1;--equip-color:#37474f;--equip-border:#cfd8dc;--step-bg:#fafafa;--autocomplete-active-bg:#fff0f0;--option-category-bg:#f5f5f5;--sl-tag-bg:#fff3e0;--sl-tag-color:#e65100;--sl-selected-bg:#f1f8e9;--sl-selected-border:#4caf50;--section-badge-bg:#e3f2fd;--section-badge-color:#1976d2;--form-section-bg:#f9f9f9;--form-section-border:#f0f0f0}[data-theme=dark]{--bg-primary:#1a1a2e;--bg-card:#16213e;--bg-card-alt:#1a2540;--bg-card-hover:#1e2a4a;--bg-input:#1e2a4a;--bg-toolbar:#1a2540;--text-primary:#e0e0e0;--text-secondary:#b0b0b0;--text-muted:grey;--text-faint:#707070;--border:#2a3a5c;--border-strong:#3a4a6c;--border-faint:#222e48;--shadow-sm:0 1px 4px rgba(0,0,0,.3);--shadow-md:0 2px 8px rgba(0,0,0,.4);--shadow-lg:0 4px 12px rgba(0,0,0,.5);--modal-overlay:rgba(0,0,0,.7);--tag-cuisine-bg:#1a3a5c;--tag-cuisine-color:#64b5f6;--tag-meal-bg:#2a1a3e;--tag-meal-color:#ce93d8;--difficulty-easy-bg:#1b3a2a;--difficulty-easy-color:#81c784;--difficulty-medium-bg:#3a2a1a;--difficulty-medium-color:#ffb74d;--difficulty-hard-bg:#3a1a1a;--difficulty-hard-color:#ef9a9a;--error-bg:#3a1a1a;--error-color:#ef9a9a;--error-border:#ef5350;--fav-hover-bg:#3a1a1a;--fav-color:#ef5350;--equip-bg:#1a2540;--equip-color:#b0bec5;--equip-border:#2a3a5c;--step-bg:#1a2540;--autocomplete-active-bg:#2a1a2a;--option-category-bg:#1a2540;--sl-tag-bg:#3a2a1a;--sl-tag-color:#ffb74d;--sl-selected-bg:#1a3a2a;--sl-selected-border:#4caf50;--section-badge-bg:#1a3a5c;--section-badge-color:#64b5f6;--form-section-bg:#1a2540;--form-section-border:#2a3a5c}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;background-color:var(--bg-primary);color:#333;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;transition:background-color .3s,color .3s}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root,body,html{height:100%;width:100%}button{cursor:pointer;font-family:inherit}input,select,textarea{background-color:#fff;background-color:var(--bg-input);color:#333;color:var(--text-primary);font-family:inherit}.login-container{align-items:center;background:linear-gradient(135deg,#ff6b6b,#ee5a24 50%,#ff6b6b);display:flex;justify-content:center;min-height:100vh;padding:1rem}.login-card{background:#fff;border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.2);max-width:380px;padding:2.5rem;width:100%}.login-title{color:#ff6b6b;font-size:2.2rem;letter-spacing:1px;margin-bottom:.25rem;text-align:center}.login-subtitle{color:#888;font-size:.95rem;margin-bottom:2rem;text-align:center}.error-message{background-color:#ffe5e5;border-left:4px solid #d32f2f;border-radius:4px;color:#d32f2f;margin-bottom:1rem;padding:.75rem}.form-group input{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem;transition:border-color .3s;width:100%}.form-group input:focus{border-color:#ff6b6b;box-shadow:0 0 0 3px hsla(0,100%,71%,.1);outline:none}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.submit-button{background-color:#ff6b6b;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-bottom:1rem;padding:.75rem;transition:background-color .3s;width:100%}.submit-button:hover:not(:disabled){background-color:#ff5252}.submit-button:disabled{background-color:#ffb3b3;cursor:not-allowed}.divider{align-items:center;color:#999;display:flex;font-size:.85rem;margin:1.5rem 0}.divider:after,.divider:before{background-color:#ddd;content:"";flex:1 1;height:1px}.divider:before{margin-right:.75rem}.divider:after{margin-left:.75rem}.google-login-container{display:flex;justify-content:center;margin-bottom:1rem}.google-login-container>div{width:100%!important}.toggle-button{background-color:transparent;border:2px solid #ff6b6b;border-radius:4px;color:#ff6b6b;cursor:pointer;font-size:.9rem;font-weight:600;padding:.75rem;transition:all .3s;width:100%}.toggle-button:hover:not(:disabled){background-color:#ffe5e5}.toggle-button:disabled{cursor:not-allowed;opacity:.5}[data-theme=dark] .login-container{background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#1a1a2e)}[data-theme=dark] .login-card{background:var(--bg-card);box-shadow:0 20px 60px rgba(0,0,0,.5)}[data-theme=dark] .login-subtitle{color:var(--text-faint)}[data-theme=dark] .error-message{background-color:var(--error-bg);border-left-color:var(--error-border);color:var(--error-color)}[data-theme=dark] .form-group input{background-color:var(--bg-input);border-color:var(--border-strong);color:var(--text-primary)}[data-theme=dark] .form-group input:disabled{background-color:var(--bg-card-alt)}[data-theme=dark] .toggle-button:hover:not(:disabled){background-color:var(--accent-light)}.skeleton-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;display:flex;flex-direction:column;overflow:hidden}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.sk-image,.sk-line{animation:shimmer 1.6s linear infinite;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background:linear-gradient(90deg,var(--bg-card-alt,#f0f0f0) 25%,var(--border,#e0e0e0) 50%,var(--bg-card-alt,#f0f0f0) 75%);background-size:800px 100%;border-radius:4px}.sk-image{border-radius:0;height:160px;width:100%}.sk-body{display:flex;flex-direction:column;gap:.5rem;padding:1.25rem}.sk-title-row{align-items:center;display:flex;gap:.75rem;margin-bottom:.25rem}.sk-title{flex:1 1;height:18px}.sk-badge{border-radius:10px;flex-shrink:0;height:22px;width:56px}.sk-desc1{height:13px;width:100%}.sk-desc2{height:13px;width:70%}.sk-tags-row{display:flex;gap:.5rem;margin:.25rem 0}.sk-tag{border-radius:4px;height:22px;width:72px}.sk-footer{border-top:1px solid #f0f0f0;border-top:1px solid var(--border-faint,#f0f0f0);display:flex;gap:.75rem;margin-top:.25rem;padding-top:.75rem}.sk-footer-item{height:14px;width:64px}.toast-container{bottom:1.5rem;display:flex;flex-direction:column;gap:.6rem;pointer-events:none;position:fixed;right:1.5rem;z-index:9999}.toast{align-items:center;animation:toast-in .28s ease;border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.15);display:flex;font-size:.9rem;font-weight:500;gap:.6rem;max-width:360px;padding:.75rem 1rem;pointer-events:all}@keyframes toast-in{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.toast-success{background:#e8f5e9;border-left:4px solid #4caf50;color:#1b5e20}.toast-error{background:#ffebee;border-left:4px solid #e53935;color:#b71c1c}.toast-info{background:#e3f2fd;border-left:4px solid #1976d2;color:#0d47a1}.toast-icon{flex-shrink:0;font-size:1rem}.toast-message{flex:1 1;line-height:1.4}.toast-close{background:none;border:none;color:inherit;cursor:pointer;flex-shrink:0;font-size:1.1rem;line-height:1;opacity:.6;padding:0 2px}.toast-close:hover{opacity:1}[data-theme=dark] .toast-success{background:rgba(76,175,80,.15);border-left-color:#4caf50;color:#a5d6a7}[data-theme=dark] .toast-error{background:rgba(229,57,53,.15);border-left-color:#e53935;color:#ef9a9a}[data-theme=dark] .toast-info{background:rgba(25,118,210,.15);border-left-color:#1976d2;color:#90caf9}@media (max-width:480px){.toast-container{bottom:1rem;left:.75rem;right:.75rem}.toast{max-width:100%}}.header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.header h2{color:#333;flex:1 1;font-size:1.75rem;margin:0}.header-actions{display:flex;flex-wrap:wrap;gap:.75rem}.btn-primary{background-color:#ff6b6b;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:.6rem 1.25rem;transition:all .2s}.btn-primary:hover{background-color:#ff5252;box-shadow:0 3px 8px hsla(0,100%,71%,.3);transform:translateY(-1px)}.btn-create{background-color:#4caf50}.btn-create:hover{background-color:#45a049;box-shadow:0 3px 8px rgba(76,175,80,.3)}.error-banner{font-size:.95rem;padding:.75rem 1rem}.loading{color:#999;font-size:1rem;padding:2rem;text-align:center}.empty-state{padding:3rem 1rem;text-align:center}.empty-state p{font-size:1.1rem;margin:0}.recipes-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.recipe-card{background:#fff;border:1px solid #eee;border-radius:8px;box-shadow:0 1px 4px rgba(0,0,0,.08);cursor:pointer;display:flex;flex-direction:column;overflow:hidden;transition:all .2s}.recipe-card:hover{border-color:#ddd;box-shadow:0 4px 12px rgba(0,0,0,.12);transform:translateY(-2px)}.recipe-card:focus{outline:2px solid #ff6b6b;outline-offset:2px}.card-image{background-color:#f5f5f5;height:160px;overflow:hidden;width:100%}.card-image img{height:100%;object-fit:cover;transition:transform .3s;width:100%}.recipe-card:hover .card-image img{transform:scale(1.05)}.card-content{display:flex;flex:1 1;flex-direction:column;padding:1.25rem}.card-header{align-items:flex-start;display:flex;gap:.75rem;justify-content:space-between;margin-bottom:.5rem}.card-header h3{color:#333;flex:1 1;font-size:1.15rem;line-height:1.3;margin:0}.difficulty{border-radius:10px;font-size:.7rem;font-weight:600;letter-spacing:.5px;padding:.2rem .6rem;text-transform:uppercase;white-space:nowrap}.difficulty-easy{background-color:#c8e6c9;color:#2e7d32}.difficulty-medium{background-color:#ffe0b2;color:#e65100}.difficulty-hard{background-color:#ffcdd2;color:#c62828}.card-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#666;display:-webkit-box;font-size:.9rem;line-height:1.4;margin:.5rem 0;overflow:hidden}.card-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.tag{border-radius:4px;font-size:.7rem;font-weight:500;padding:.2rem .5rem}.card-footer{border-top:1px solid #f0f0f0;font-size:.85rem;gap:.5rem;justify-content:space-between;margin-top:auto;padding-top:.75rem}.btn-like,.card-footer{align-items:center;color:#999;display:flex}.btn-like{background:none;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;gap:.25rem;padding:.2rem .4rem;transition:all .2s}.btn-like:hover{background-color:#fff0f0;transform:scale(1.1)}.btn-like.liked{color:#e53935}.like-count{font-size:.8rem;font-weight:500}.btn-bookmark{align-items:center;background:none;border:1.5px solid #bbb;border-radius:14px;color:#666;cursor:pointer;display:flex;font-size:.75rem;font-weight:600;gap:.3rem;padding:.25rem .6rem;transition:all .2s;white-space:nowrap}.btn-bookmark:hover{transform:scale(1.05)}.btn-bookmark.bookmarked,.btn-bookmark:hover{background-color:#e3f2fd;border-color:#1976d2;color:#1976d2}.tabs{border-bottom:2px solid #eee;display:flex;gap:0;margin-bottom:1.25rem}.tab{background:none;border:none;border-bottom:2px solid transparent;color:#888;cursor:pointer;font-size:.95rem;font-weight:500;margin-bottom:-2px;padding:.6rem 1.25rem;transition:all .2s}.tab:hover{background-color:#fafafa;color:#555}.tab-active{border-bottom-color:#ff6b6b;color:#ff6b6b;font-weight:600}.search-filter-bar{background:#fff;border:1px solid #eee;border-radius:8px;box-shadow:0 1px 4px rgba(0,0,0,.08);margin-bottom:1.5rem;padding:1rem}.search-row{margin-bottom:.75rem}.search-input{border:1px solid #ddd;border-radius:6px;font-size:1rem;padding:.75rem 1rem;transition:border-color .2s,box-shadow .2s;width:100%}.search-input:focus{border-color:#ff6b6b;box-shadow:0 0 0 3px hsla(0,100%,71%,.1);outline:none}.filter-row{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.filter-select{background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:.9rem;min-width:140px;padding:.5rem .75rem;transition:border-color .2s}.filter-select:focus{border-color:#ff6b6b;outline:none}.btn-clear-filters{background:#f5f5f5;border:1px solid #ddd;border-radius:6px;color:#666;cursor:pointer;font-size:.85rem;padding:.5rem 1rem;transition:all .2s}.btn-clear-filters:hover{background:#eee;color:#333}@media (max-width:768px){.recipes-grid{grid-template-columns:1fr}.header{align-items:stretch;flex-direction:column}.header h2{font-size:1.5rem}.btn-primary{width:100%}.filter-row{flex-direction:column}.btn-clear-filters,.filter-select{width:100%}}[data-theme=dark] .header h2{color:var(--text-primary)}[data-theme=dark] .empty-state,[data-theme=dark] .empty-state p,[data-theme=dark] .loading{color:var(--text-muted)}[data-theme=dark] .recipe-card{background:var(--bg-card);border-color:var(--border);box-shadow:var(--shadow-sm)}[data-theme=dark] .recipe-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-lg)}[data-theme=dark] .card-image{background-color:var(--bg-card-alt)}[data-theme=dark] .card-header h3{color:var(--text-primary)}[data-theme=dark] .difficulty-easy{background-color:var(--difficulty-easy-bg);color:var(--difficulty-easy-color)}[data-theme=dark] .difficulty-medium{background-color:var(--difficulty-medium-bg);color:var(--difficulty-medium-color)}[data-theme=dark] .difficulty-hard{background-color:var(--difficulty-hard-bg);color:var(--difficulty-hard-color)}[data-theme=dark] .card-description{color:var(--text-secondary)}[data-theme=dark] .card-footer{border-top-color:var(--border-faint);color:var(--text-muted)}[data-theme=dark] .btn-like{color:var(--text-muted)}[data-theme=dark] .btn-like:hover{background-color:var(--fav-hover-bg)}[data-theme=dark] .btn-like.liked{color:var(--fav-color)}[data-theme=dark] .btn-bookmark{border-color:var(--border-strong);color:var(--text-muted)}[data-theme=dark] .btn-bookmark.bookmarked,[data-theme=dark] .btn-bookmark:hover{background-color:rgba(30,60,120,.25);border-color:#64b5f6;color:#64b5f6}[data-theme=dark] .tabs{border-bottom-color:var(--border)}[data-theme=dark] .tab{color:var(--text-faint)}[data-theme=dark] .tab:hover{background-color:var(--bg-card-hover);color:var(--text-secondary)}[data-theme=dark] .search-filter-bar{background:var(--bg-card);border-color:var(--border);box-shadow:var(--shadow-sm)}[data-theme=dark] .search-input{background-color:var(--bg-input);border-color:var(--border-strong);color:var(--text-primary)}[data-theme=dark] .filter-select{background:var(--bg-input);border-color:var(--border-strong);color:var(--text-primary)}[data-theme=dark] .btn-clear-filters{background:var(--bg-card-alt);border-color:var(--border-strong);color:var(--text-secondary)}[data-theme=dark] .btn-clear-filters:hover{background:var(--border);color:var(--text-primary)}.btn-back{background-color:#f0f0f0;border:1px solid #ddd;border-radius:4px;color:#333;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .3s}.btn-back:hover{background-color:#e0e0e0}.recipe-detail{background:#fff;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.1);overflow:hidden;padding:2rem}.recipe-hero-image{margin:-2rem -2rem 1.5rem;max-height:400px;overflow:hidden}.recipe-hero-image img{display:block;height:auto;max-height:400px;object-fit:cover;width:100%}.recipe-header{margin-bottom:1rem}.recipe-header-top{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.75rem}.recipe-header h1{color:#333;flex:1 1;font-size:2rem;margin:0}.recipe-meta{flex-shrink:0;flex-wrap:wrap;gap:.5rem}.btn-like-detail,.recipe-meta{align-items:center;display:flex}.btn-like-detail{background:none;border:1px solid #e0e0e0;border-radius:6px;color:#888;cursor:pointer;font-size:.95rem;gap:.35rem;padding:.4rem .75rem;transition:all .2s}.btn-like-detail.liked,.btn-like-detail:hover{background-color:#fff0f0;border-color:#e53935;color:#e53935}.btn-bookmark-detail{align-items:center;background:none;border:1.5px solid #bbb;border-radius:18px;color:#666;cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:.35rem;padding:.4rem .85rem;transition:all .2s}.btn-bookmark-detail.bookmarked,.btn-bookmark-detail:hover{background-color:#e3f2fd;border-color:#1976d2;color:#1976d2}.category-tag{border-radius:4px;font-size:.85rem;font-weight:500;padding:.4rem .75rem}.tag-cuisine{background-color:#e3f2fd;color:#1565c0}.tag-meal-type{background-color:#f3e5f5;color:#7b1fa2}.recipe-toolbar{background:#f9f9f9;border:1px solid #eee;border-radius:6px;justify-content:space-between;padding:.5rem .75rem}.recipe-toolbar,.toolbar-left{align-items:center;display:flex}.toolbar-left{gap:.25rem}.btn-action{align-items:center;background:transparent;border:none;border-radius:4px;color:#555;cursor:pointer;display:inline-flex;font-size:.8rem;font-weight:500;gap:.3rem;padding:.35rem .75rem;transition:all .15s;white-space:nowrap}.btn-action:hover:not(:disabled){background:#e8e8e8}.btn-action-primary{background:#4caf50;color:#fff}.btn-action-primary:hover:not(:disabled){background:#45a049}.btn-action-secondary{color:#555}.btn-action-secondary:hover:not(:disabled){background:#e8e8e8;color:#333}.btn-action-danger{color:#999;font-size:.85rem}.btn-action-danger:hover:not(:disabled){background:#ffebee;color:#d32f2f}.btn-action:disabled{cursor:not-allowed;opacity:.5}.recipe-detail .description{color:#666;font-size:1.1rem;font-style:italic;line-height:1.6;margin-bottom:1.5rem}.info-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin-bottom:1.5rem}.info-card{background:#f9f9f9;border:1px solid #eee;border-radius:8px;padding:1rem 1.25rem;text-align:center}.info-card h4{color:#555;font-size:.85rem;margin:0 0 .35rem}.info-card p{color:#ff6b6b;font-size:1.3rem;font-weight:700;margin:0}.scale-multiplier-bar{gap:.3rem;margin-top:.5rem}.btn-multiplier,.scale-multiplier-bar{align-items:center;display:flex;justify-content:center}.btn-multiplier{background:#fff;border:1px solid #ddd;border-radius:4px;color:#888;cursor:pointer;font-size:.75rem;font-weight:600;height:1.75rem;line-height:1;padding:0;transition:all .2s;width:2rem}.btn-multiplier:hover{border-color:#ff6b6b;color:#ff6b6b}.btn-multiplier.active{background:#ff6b6b;border-color:#ff6b6b;color:#fff}.ingredient-list-qty.scaled{color:#ff6b6b;font-weight:600}.equipment-section{margin-bottom:1.5rem}.equipment-section h2{border-bottom:2px solid #607d8b;color:#333;font-size:1.3rem;margin-bottom:.75rem;padding-bottom:.5rem}.equipment-tags{display:flex;flex-wrap:wrap;gap:.5rem}.equipment-tag{align-items:center;background-color:#eceff1;border:1px solid #cfd8dc;border-radius:20px;color:#37474f;display:inline-flex;font-size:.9rem;font-weight:500;padding:.4rem .85rem}.recipe-two-column{grid-gap:0;align-items:start;border:1px solid #eee;border-radius:8px;display:grid;gap:0;grid-template-columns:minmax(220px,280px) 1fr;overflow:hidden}.recipe-two-column .ingredients-column{background-color:#fafafa;border-right:1px solid #eee;margin-bottom:0;padding:1.25rem;position:sticky;top:4.5rem}.recipe-two-column .ingredients-column h2{border-bottom:none;font-size:1.15rem;margin-bottom:.5rem}.recipe-two-column .instructions-column{margin-bottom:0;min-height:0;padding:1.25rem}.recipe-two-column .instructions-column h2{border-bottom:none;font-size:1.15rem;margin-bottom:.5rem}.section-two-column{grid-gap:0;align-items:start;border:1px solid #eee;border-radius:6px;display:grid;gap:0;grid-template-columns:minmax(200px,260px) 1fr;overflow:hidden}.section-two-column .ingredients-subsection{background-color:#fafafa;border-right:1px solid #eee;height:100%;padding:1rem 1.25rem}.section-two-column .instructions-subsection{border-radius:0;padding:1rem 1.25rem}.ingredients-list-compact{list-style:none;margin:0;padding:0}.ingredients-list-compact .ingredient-list-item{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;margin-left:0;padding:.5rem 0}.ingredients-list-compact .ingredient-list-item:last-child{border-bottom:none}.ingredients-list-compact .ingredient-list-item:before{content:none}.ingredients-list-styled{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr);list-style:none;margin:0 0 .5rem;padding:0}.ingredient-list-item{align-items:center;display:flex;gap:.5rem;margin-left:1.25rem;position:relative}.ingredient-list-item:before{color:#ff6b6b;content:"•";font-size:1.2rem;font-weight:700;left:-1.25rem;position:absolute}.ingredient-list-name{color:#333;font-weight:500}.ingredient-list-qty{color:#666;flex-shrink:0;font-size:.85rem;white-space:nowrap}.section{margin-bottom:.5rem}.section h2{border-bottom:2px solid #ff6b6b;color:#333;font-size:1.3rem;margin-bottom:.75rem;padding-bottom:.5rem}@media (max-width:768px){.recipe-detail{padding:1.5rem}.recipe-header-top{flex-direction:column}.recipe-header h1{font-size:1.8rem}.info-grid{grid-template-columns:repeat(2,1fr)}.info-card{padding:.75rem}.info-card h4{font-size:.8rem}.info-card p,.section h2{font-size:1.1rem}.recipe-two-column{border:none;border-radius:0;grid-template-columns:1fr}.recipe-two-column .ingredients-column{background-color:transparent;border-bottom:1px solid #eee;border-right:none;position:static}.recipe-two-column .instructions-column{padding:1.25rem 0}.section-content.section-two-column,.section-two-column{border:none;border-radius:0;display:flex;flex-direction:column;gap:1rem;grid-template-columns:1fr}.section-two-column .ingredients-subsection{background-color:transparent;border-bottom:1px solid #eee;border-right:none}.section-two-column .instructions-subsection{padding:1rem 0}}.section-header-button{align-items:center;background:none;border:none;cursor:pointer;display:flex;justify-content:space-between;margin:0;padding:0;transition:all .2s;width:100%}.section-header-button h2,.section-header-button h3{color:#ff6b6b;font-size:1.3rem;margin:0}.section-header-button:hover h2,.section-header-button:hover h3{text-decoration:underline}.expand-icon{color:#ff6b6b;font-size:1.3em;margin-left:1rem;transition:transform .2s}.section-content{display:flex;flex-direction:column;gap:1.5rem;margin-top:1rem}.section-content.section-two-column{grid-gap:0;display:grid;flex-direction:row;gap:0;margin-top:1rem}.ingredients-subsection h3,.ingredients-subsection h4,.instructions-subsection h3,.instructions-subsection h4{color:#555;font-size:1rem;margin-bottom:.75rem;margin-top:0}.instructions-subsection{background-color:#fff;border-radius:4px;line-height:1.6;padding:1rem}.recipe-two-column .section{margin-bottom:0}.recipe-two-column .section h2,.section-two-column .ingredients-subsection,.section-two-column .instructions-subsection{margin-top:0}.steps-display{display:flex;flex-direction:column;gap:.6rem}.step-item{background-color:#fafafa;border-left:3px solid #ff6b6b;border-radius:2px;font-size:.95rem;line-height:1.5;padding:.6rem .85rem}.modal-overlay{align-items:center;background-color:rgba(0,0,0,.5);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background-color:#fff;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.15);max-width:400px;padding:2rem;width:90%}.modal-content h2{color:#333;font-size:1.5rem;margin-bottom:1rem;margin-top:0}.modal-content p{color:#666;line-height:1.5;margin-bottom:2rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.btn-cancel{border-radius:4px;cursor:pointer;font-size:.95rem;padding:.75rem 1.5rem;transition:background-color .3s}.btn-cancel:disabled{opacity:.6}.btn-confirm-delete{background-color:#ff6b6b;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.95rem;padding:.75rem 1.5rem;transition:background-color .3s}.btn-confirm-delete:hover:not(:disabled){background-color:#ff5252}.btn-confirm-delete:disabled{background-color:#ccc;cursor:not-allowed}@media (max-width:1024px){.ingredients-list-styled{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.ingredients-list-styled{grid-template-columns:1fr}.expand-icon{font-size:1em}.modal-content{padding:1.5rem}.modal-actions{flex-direction:column}.btn-cancel,.btn-confirm-delete{width:100%}}[data-theme=dark] .btn-back{background-color:var(--bg-card-alt);border-color:var(--border-strong);color:var(--text-primary)}[data-theme=dark] .btn-back:hover{background-color:var(--border)}[data-theme=dark] .recipe-detail{background:var(--bg-card);box-shadow:var(--shadow-md)}[data-theme=dark] .recipe-header h1{color:var(--text-primary)}[data-theme=dark] .btn-like-detail{border-color:var(--border-strong);color:var(--text-faint)}[data-theme=dark] .btn-like-detail.liked,[data-theme=dark] .btn-like-detail:hover{background-color:var(--fav-hover-bg);border-color:var(--fav-color);color:var(--fav-color)}[data-theme=dark] .btn-bookmark-detail{border-color:var(--border-strong);color:var(--text-faint)}[data-theme=dark] .btn-bookmark-detail.bookmarked,[data-theme=dark] .btn-bookmark-detail:hover{background-color:rgba(30,60,120,.25);border-color:#64b5f6;color:#64b5f6}[data-theme=dark] .tag-cuisine{background-color:var(--tag-cuisine-bg);color:var(--tag-cuisine-color)}[data-theme=dark] .tag-meal-type{background-color:var(--tag-meal-bg);color:var(--tag-meal-color)}[data-theme=dark] .recipe-toolbar{background:var(--bg-toolbar);border-color:var(--border)}[data-theme=dark] .btn-action{color:var(--text-secondary)}[data-theme=dark] .btn-action-secondary:hover:not(:disabled),[data-theme=dark] .btn-action:hover:not(:disabled){background:var(--border);color:var(--text-primary)}[data-theme=dark] .btn-action-danger{color:var(--text-muted)}[data-theme=dark] .btn-action-danger:hover:not(:disabled){background:var(--error-bg);color:var(--error-color)}[data-theme=dark] .recipe-detail .description{color:var(--text-secondary)}[data-theme=dark] .info-card{background:var(--bg-card-alt);border-color:var(--border)}[data-theme=dark] .info-card h4{color:var(--text-secondary)}[data-theme=dark] .btn-multiplier{background:var(--bg-card);border-color:var(--border-strong);color:var(--text-faint)}[data-theme=dark] .btn-multiplier:hover{border-color:var(--accent);color:var(--accent)}[data-theme=dark] .equipment-section h2{color:var(--text-primary)}[data-theme=dark] .equipment-tag{background-color:var(--equip-bg);border-color:var(--equip-border);color:var(--equip-color)}[data-theme=dark] .recipe-two-column{border-color:var(--border)}[data-theme=dark] .recipe-two-column .ingredients-column{background-color:var(--bg-card-alt);border-right-color:var(--border)}[data-theme=dark] .section-two-column{border-color:var(--border)}[data-theme=dark] .section-two-column .ingredients-subsection{background-color:var(--bg-card-alt);border-right-color:var(--border)}[data-theme=dark] .ingredients-list-compact .ingredient-list-item{border-bottom-color:var(--border-faint)}[data-theme=dark] .ingredient-list-name{color:var(--text-primary)}[data-theme=dark] .ingredient-list-qty{color:var(--text-secondary)}[data-theme=dark] .section h2{color:var(--text-primary)}[data-theme=dark] .section-header-button h2,[data-theme=dark] .section-header-button h3{color:var(--accent)}[data-theme=dark] .ingredients-subsection h3,[data-theme=dark] .ingredients-subsection h4,[data-theme=dark] .instructions-subsection h3,[data-theme=dark] .instructions-subsection h4{color:var(--text-secondary)}[data-theme=dark] .instructions-subsection{background-color:var(--bg-card)}[data-theme=dark] .step-item{background-color:var(--step-bg)}[data-theme=dark] .modal-overlay{background-color:var(--modal-overlay)}[data-theme=dark] .modal-content{background-color:var(--bg-card);box-shadow:var(--shadow-lg)}[data-theme=dark] .modal-content h2{color:var(--text-primary)}[data-theme=dark] .modal-content p{color:var(--text-secondary)}@media print{.btn-back,.btn-bookmark-detail,.btn-like-detail,.modal-overlay,.navbar,.recipe-toolbar,.scale-multiplier-bar{display:none!important}body{background:#fff!important;margin:0;padding:0}.app{min-height:auto}.container{margin:0;max-width:100%;padding:0}.recipe-detail{border:none;box-shadow:none;padding:0}.recipe-hero-image{margin:0 0 1rem;max-height:250px}.recipe-header-top{flex-direction:column}.recipe-header h1{font-size:1.6rem}.recipe-meta{display:flex;gap:.5rem}.recipe-meta .category-tag,.recipe-meta .difficulty{font-size:.75rem;padding:.15rem .5rem}.description{font-size:.95rem;margin-bottom:1rem}.info-grid{gap:.5rem;grid-template-columns:repeat(4,1fr);margin-bottom:1rem}.info-card{border:1px solid #ccc;padding:.5rem}.info-card h4{font-size:.75rem}.info-card p{color:#333!important;font-size:1rem}.recipe-two-column{display:block}.recipe-two-column .ingredients-column{background:none;border-bottom:1px solid #ccc;border-right:none;position:static}.section-two-column{display:block}.section-two-column .ingredients-subsection{background:none;border-bottom:1px solid #ccc;border-right:none}.section-header-button{pointer-events:none}.section-content{display:block!important}.expand-icon{display:none}.ingredient-list-qty.scaled{color:#333;font-weight:600}.equipment-section{margin-bottom:.75rem}.section,.step-item{page-break-inside:avoid}}.ingredient-autocomplete{flex:1 1;position:relative}.ingredient-autocomplete input{border:1px solid #ddd;border-radius:6px;box-sizing:border-box;font-size:.95rem;padding:.5rem .75rem;transition:border-color .2s,box-shadow .2s;width:100%}.ingredient-autocomplete input:focus{border-color:#ff6b6b;box-shadow:0 0 0 3px hsla(0,100%,71%,.1);outline:none}.autocomplete-dropdown{background:#fff;border:1px solid #ddd;border-radius:0 0 6px 6px;border-top:none;box-shadow:0 4px 12px rgba(0,0,0,.1);left:0;list-style:none;margin:0;max-height:200px;overflow-y:auto;padding:0;position:absolute;right:0;top:100%;z-index:50}.autocomplete-option{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:.5rem .75rem;transition:background-color .1s}.autocomplete-option.active,.autocomplete-option:hover{background-color:#fff0f0}.option-name{color:#333;font-size:.9rem}.option-category{background:#f5f5f5;border-radius:3px;color:#999;font-size:.75rem;padding:.1rem .4rem}[data-theme=dark] .ingredient-autocomplete input{background-color:var(--bg-input);border-color:var(--border-strong);color:var(--text-primary)}[data-theme=dark] .autocomplete-dropdown{background:var(--bg-card);border-color:var(--border-strong);box-shadow:var(--shadow-lg)}[data-theme=dark] .autocomplete-option.active,[data-theme=dark] .autocomplete-option:hover{background-color:var(--autocomplete-active-bg)}[data-theme=dark] .option-name{color:var(--text-primary)}[data-theme=dark] .option-category{background:var(--option-category-bg);color:var(--text-muted)}.import-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:rgba(0,0,0,.55);display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1000}.import-modal{animation:importModalIn .2s ease;background:#fff;background:var(--color-surface,#fff);border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.25);display:flex;flex-direction:column;max-height:90vh;max-width:560px;overflow:hidden;width:100%}@keyframes importModalIn{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.import-modal-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--color-border,#e5e7eb);display:flex;justify-content:space-between;padding:20px 24px 16px}.import-modal-header h2{color:#111;color:var(--color-text,#111);font-size:1.2rem;font-weight:700;margin:0}.import-close-btn{background:none;border:none;border-radius:6px;color:#6b7280;color:var(--color-text-secondary,#6b7280);cursor:pointer;font-size:1.1rem;padding:4px 8px;transition:background .15s}.import-close-btn:hover{background:#f3f4f6;background:var(--color-surface-hover,#f3f4f6)}.import-tabs{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--color-border,#e5e7eb);display:flex}.import-tab{background:none;border:none;border-bottom:3px solid transparent;color:#6b7280;color:var(--color-text-secondary,#6b7280);cursor:pointer;flex:1 1;font-size:.95rem;font-weight:500;padding:12px 16px;transition:color .15s,border-color .15s}.import-tab.active{border-bottom-color:#f97316;border-bottom-color:var(--color-primary,#f97316);color:#f97316;color:var(--color-primary,#f97316)}.import-tab:hover:not(.active){background:#f9fafb;background:var(--color-surface-hover,#f9fafb);color:#111;color:var(--color-text,#111)}.import-body{display:flex;flex-direction:column;gap:12px;overflow-y:auto;padding:20px 24px}.import-hint{color:#6b7280;color:var(--color-text-secondary,#6b7280);font-size:.875rem;line-height:1.5;margin:0}.import-input{background:#fff;background:var(--color-bg,#fff);border:1px solid #d1d5db;border:1px solid var(--color-border,#d1d5db);border-radius:8px;box-sizing:border-box;color:#111;color:var(--color-text,#111);font-size:.95rem;padding:10px 14px;transition:border-color .15s,box-shadow .15s;width:100%}.import-input:focus{border-color:#f97316;border-color:var(--color-primary,#f97316);box-shadow:0 0 0 3px rgba(249,115,22,.15);outline:none}.import-textarea{background:#fff;background:var(--color-bg,#fff);border:1px solid #d1d5db;border:1px solid var(--color-border,#d1d5db);border-radius:8px;box-sizing:border-box;color:#111;color:var(--color-text,#111);font-family:monospace;font-size:.85rem;min-height:160px;padding:10px 14px;resize:vertical;transition:border-color .15s,box-shadow .15s;width:100%}.import-textarea:focus{border-color:#f97316;border-color:var(--color-primary,#f97316);box-shadow:0 0 0 3px rgba(249,115,22,.15);outline:none}.btn-import-action{align-self:flex-end;background:#f97316;background:var(--color-primary,#f97316);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:10px 22px;transition:opacity .15s,transform .1s}.btn-import-action:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-import-action:disabled{cursor:not-allowed;opacity:.5}.import-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.875rem;margin:0 24px 16px;padding:10px 14px}.import-preview{display:flex;flex-direction:column;gap:14px;overflow-y:auto;padding:20px 24px}.import-preview-label{color:#16a34a;font-size:.9rem;font-weight:600;margin:0}.import-preview-card{background:#fff;background:var(--color-surface,#fff);border:1px solid #e5e7eb;border:1px solid var(--color-border,#e5e7eb);border-radius:12px;overflow:hidden}.import-preview-img{display:block;height:160px;object-fit:cover;width:100%}.import-preview-name{color:#111;color:var(--color-text,#111);font-size:1.05rem;font-weight:700;margin:12px 16px 4px}.import-preview-desc{color:#6b7280;color:var(--color-text-secondary,#6b7280);font-size:.85rem;line-height:1.5;margin:0 16px 8px}.import-preview-meta{display:flex;flex-wrap:wrap;gap:8px;padding:0 16px 8px}.import-preview-meta span{background:#f3f4f6;background:var(--color-surface-hover,#f3f4f6);border-radius:99px;color:#374151;color:var(--color-text,#374151);font-size:.8rem;padding:3px 10px}.import-preview-counts{border-top:1px solid #f3f4f6;border-top:1px solid var(--color-border,#f3f4f6);color:#9ca3af;color:var(--color-text-secondary,#9ca3af);font-size:.8rem;margin:0;padding:8px 16px 12px}.import-preview-actions{display:flex;gap:10px;justify-content:flex-end}.btn-import-back{background:none;border:1px solid #d1d5db;border:1px solid var(--color-border,#d1d5db);border-radius:8px;color:#6b7280;color:var(--color-text-secondary,#6b7280);cursor:pointer;font-size:.9rem;padding:10px 18px;transition:background .15s}.btn-import-back:hover{background:#f3f4f6;background:var(--color-surface-hover,#f3f4f6)}.btn-import-confirm{background:#16a34a;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:10px 22px;transition:opacity .15s,transform .1s}.btn-import-confirm:hover{opacity:.9;transform:translateY(-1px)}.create-recipe-container{margin:0 auto;max-width:800px;padding:0}.create-recipe-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.1);margin-bottom:2rem;padding:2rem}.create-recipe-title-row{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:1.5rem}.create-recipe-title-row h1{color:#333;font-size:2rem;margin:0}.btn-import-recipe{align-items:center;background:#fff;border:1.5px solid #f97316;border-radius:8px;color:#f97316;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:600;gap:6px;padding:9px 18px;transition:background .15s,color .15s;white-space:nowrap}.btn-import-recipe:hover{background:#f97316;color:#fff}.create-recipe-card h1{color:#333;font-size:2rem;margin-bottom:1.5rem;margin-top:0}.error-banner{background-color:#ffe5e5;border-left:4px solid #d32f2f;border-radius:4px;color:#d32f2f;padding:1rem}.error-banner,.form-group{margin-bottom:1.5rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.form-group label{color:#333;display:block;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-family:inherit;font-size:1rem;padding:.5rem;transition:border-color .3s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#ff6b6b;box-shadow:0 0 0 3px hsla(0,100%,71%,.1);outline:none}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:#f5f5f5;cursor:not-allowed}.form-group textarea{line-height:1.5;resize:vertical}.field-help{color:#888;font-size:.8rem;margin-bottom:0;margin-top:.25rem}.image-upload-section{display:flex;flex-direction:column;gap:.5rem}.image-upload-buttons{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.btn-upload-image{align-items:center;background-color:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.6rem 1rem;transition:all .2s}.btn-upload-image:hover{background-color:#45a049}.upload-divider{color:#999;font-size:.85rem}.image-url-input{flex:1 1;min-width:200px}.image-preview{border:1px solid #ddd;border-radius:8px;margin-top:.75rem;max-width:300px;overflow:hidden;position:relative}.image-preview img{display:block;height:auto;width:100%}.btn-remove-image{background-color:rgba(0,0,0,.7);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.75rem;padding:.25rem .5rem;position:absolute;right:.5rem;top:.5rem;transition:background-color .2s}.btn-remove-image:hover{background-color:rgba(0,0,0,.9)}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.btn-back,.btn-cancel,.btn-submit{border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s}.btn-submit{background-color:#ff6b6b;color:#fff}.btn-submit:hover:not(:disabled){background-color:#ff5252;box-shadow:0 4px 12px hsla(0,100%,71%,.3);transform:translateY(-2px)}.btn-submit:disabled{background-color:#ffb3b3;cursor:not-allowed}.btn-cancel{background-color:#f0f0f0;border:1px solid #ddd;color:#333}.btn-cancel:hover:not(:disabled){background-color:#e0e0e0}.btn-cancel:disabled{cursor:not-allowed;opacity:.5}.btn-back{background-color:transparent;border:1px solid #ff6b6b;color:#ff6b6b;margin-bottom:2rem}.btn-back:hover{background-color:#ffe5e5}.form-section-divider{border-top:2px solid #f0f0f0;margin:2.5rem 0 1.5rem;padding:1rem 0 0}.form-section-divider h2{color:#333;font-size:1.3rem;font-weight:600;margin:0 0 .25rem}.section-help{color:#999;font-size:.9rem;margin:0}.ingredients-form{border:1px solid #f0f0f0;border-radius:4px;padding:1.5rem}.btn-toggle-ingredient-form{background-color:#f0f0f0;border:1px solid #ddd;border-radius:4px;color:#333;cursor:pointer;font-size:.95rem;font-weight:600;margin-bottom:1rem;padding:.75rem 1.5rem;text-align:left;transition:all .3s;width:100%}.btn-toggle-ingredient-form:hover:not(:disabled){background-color:#e8e8e8}.btn-toggle-ingredient-form:disabled{cursor:not-allowed;opacity:.5}.add-section-form{background-color:#f9f9f9;border:1px solid #f0f0f0;border-radius:4px;margin-bottom:1.5rem;padding:1.5rem}.section-input-group{display:flex;gap:.75rem}.section-input-group input{border:1px solid #ddd;border-radius:4px;flex:1 1;font-family:inherit;font-size:1rem;padding:.75rem}.btn-add-section{background-color:#2196f3;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s;white-space:nowrap}.btn-add-section:hover:not(:disabled){background-color:#1976d2;box-shadow:0 4px 12px rgba(33,150,243,.3);transform:translateY(-2px)}.btn-add-section:disabled{cursor:not-allowed;opacity:.5}.sections-list{background-color:#f9f9f9;border:1px solid #f0f0f0;border-radius:4px;margin-bottom:1.5rem;padding:1.5rem}.sections-list h3{color:#333;font-size:1rem;margin-top:0}.sections-grid{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1rem}.section-badge{align-items:center;background-color:#e3f2fd;border-radius:20px;color:#1976d2;display:inline-flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.5rem 1rem}.btn-remove-section{background:none;border:none;color:#1976d2;font-size:1.5rem;line-height:1;padding:0;transition:color .3s}.btn-remove-section:hover{color:#d32f2f}.btn-add-ingredient{background-color:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;margin-top:1rem;padding:.75rem 1.5rem;transition:all .3s;width:100%}.btn-add-ingredient:hover:not(:disabled){background-color:#45a049;box-shadow:0 4px 12px rgba(76,175,80,.3);transform:translateY(-2px)}.btn-add-ingredient:disabled{background-color:#b8d4b8;cursor:not-allowed}.ingredients-list{background-color:#f9f9f9;border:1px solid #f0f0f0;border-radius:4px;margin-bottom:2rem;padding:1.5rem}.ingredients-list h3{color:#333;font-size:1.1rem;margin-top:0}.ingredients-list ul{list-style:none;margin:1rem 0 0;padding:0}.ingredient-item{background:#fff;border:1px solid #e0e0e0;justify-content:space-between;margin-bottom:.5rem;padding:.65rem .85rem}.ingredient-info,.ingredient-item{align-items:center;border-radius:4px;display:flex;gap:.75rem}.ingredient-info{cursor:pointer;flex:1 1;flex-wrap:wrap;margin:-.25rem -.5rem;padding:.25rem .5rem;transition:background-color .15s}.ingredient-info:hover{background-color:#f5f5f5}.ingredient-info strong{color:#333;min-width:100px}.ingredient-amount{background-color:#e8f5e9;border-radius:3px;color:#2e7d32;font-size:.85rem;font-weight:500;padding:.25rem .75rem}.ingredient-category{background-color:#f3e5f5;border-radius:3px;color:#6a1b9a;font-size:.8rem;padding:.25rem .75rem}.btn-remove{background-color:#ffebee;border:1px solid #ffcdd2;border-radius:4px;color:#d32f2f;cursor:pointer;font-size:.9rem;font-weight:600;padding:.3rem .6rem;transition:all .2s;white-space:nowrap}.btn-remove:hover{background-color:#f8bbd0}.btn-remove:disabled{cursor:not-allowed;opacity:.5}.sections-container{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.section-block{background-color:#f9f9f9;border:2px solid #ff6b6b;border-left-width:5px;border-radius:8px;padding:1.5rem}.section-header{align-items:center;border-bottom:2px solid #ff6b6b;display:flex;gap:.5rem;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.section-header h3{color:#ff6b6b;flex:1 1;font-size:1.4rem;margin:0}.section-name-edit{align-items:center;display:flex;flex:1 1;gap:.5rem}.section-name-edit input{border:2px solid #ff6b6b;border-radius:4px;flex:1 1;font-family:inherit;font-size:1.1rem;min-width:150px;padding:.5rem}.section-name-edit input:focus{box-shadow:0 0 0 3px hsla(0,100%,71%,.2);outline:none}.btn-cancel-section-name,.btn-edit-section,.btn-save-section-name{align-items:center;background-color:#fff3e0;border:1px solid #ffe0b2;border-radius:4px;color:#e65100;cursor:pointer;display:flex;flex-shrink:0;font-size:1.1rem;font-weight:700;height:36px;justify-content:center;padding:.4rem .8rem;transition:all .2s;width:36px}.btn-cancel-section-name:hover:not(:disabled),.btn-edit-section:hover:not(:disabled),.btn-save-section-name:hover:not(:disabled){background-color:#ffd699}.btn-cancel-section-name:disabled,.btn-edit-section:disabled,.btn-save-section-name:disabled{cursor:not-allowed;opacity:.6}.btn-remove-section{align-items:center;background-color:#ffebee;border:1px solid #ffcdd2;border-radius:4px;color:#d32f2f;cursor:pointer;display:flex;flex-shrink:0;font-size:1.2rem;font-weight:700;height:36px;justify-content:center;padding:.4rem .8rem;transition:all .2s;width:36px}.btn-remove-section:hover:not(:disabled){background-color:#f8bbd0}.btn-remove-section:disabled{cursor:not-allowed;opacity:.6}.section-order-buttons{display:flex;flex-direction:column;gap:2px}.btn-move-section{align-items:center;background-color:#e3f2fd;border:1px solid #bbdefb;border-radius:3px;color:#1976d2;cursor:pointer;display:flex;flex-shrink:0;font-size:.65rem;font-weight:700;height:16px;justify-content:center;line-height:1;padding:0;transition:all .2s;width:24px}.btn-move-section:hover:not(:disabled){background-color:#90caf9}.btn-move-section:disabled{background-color:#f5f5f5;border-color:#e0e0e0;color:#999;cursor:not-allowed;opacity:.35}.section-subsection{background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;margin-bottom:1.5rem;padding:1rem}.section-subsection h4{border-bottom:1px solid #e0e0e0;color:#333;font-size:1.1rem;margin:0 0 1rem;padding-bottom:.5rem}.section-ingredients-list{list-style:none;margin:0;padding:0}.empty-state{color:#999;font-style:italic;margin:.5rem 0}.section-ingredient-form{background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;margin-top:1rem;padding:1rem}.btn-toggle-section-ingredient-form{background-color:#fff;border:1px solid #ddd;border-radius:4px;color:#333;cursor:pointer;font-size:.9rem;font-weight:600;margin-bottom:1rem;padding:.6rem 1rem;text-align:left;transition:all .2s;width:100%}.btn-toggle-section-ingredient-form:hover:not(:disabled){background-color:#f5f5f5;border-color:#999}.btn-toggle-section-ingredient-form:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.create-recipe-container{padding:1rem}.create-recipe-card{padding:1.5rem}.create-recipe-card h1{font-size:1.5rem}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}.ingredient-item{align-items:flex-start;flex-direction:column}.btn-remove,.ingredient-info{width:100%}}.steps-container{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.step-input-group{align-items:center;background-color:#f9f9f9;border:1px solid #e0e0e0;border-radius:4px;display:flex;gap:.5rem;padding:.75rem}.step-number{color:#ff6b6b;font-size:.95rem;font-weight:700;min-width:25px;text-align:center}.step-input-group input{border:1px solid #ddd;border-radius:4px;flex:1 1;font-family:inherit;font-size:.95rem;padding:.6rem}.step-input-group input:focus{border-color:#ff6b6b;box-shadow:0 0 0 3px hsla(0,100%,71%,.1);outline:none}.btn-remove-step{align-items:center;background-color:#ffebee;border:1px solid #ffcdd2;border-radius:4px;color:#d32f2f;cursor:pointer;display:flex;font-size:1rem;font-weight:700;height:32px;justify-content:center;min-width:32px;padding:.4rem .6rem;transition:all .2s}.btn-remove-step:hover{background-color:#f8bbd0}.btn-remove-step:disabled{cursor:not-allowed;opacity:.6}.btn-add-step{background-color:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:.6rem 1.2rem;transition:all .2s}.btn-add-step:hover:not(:disabled){background-color:#45a049;box-shadow:0 2px 4px rgba(0,0,0,.2)}.btn-add-step:disabled{cursor:not-allowed;opacity:.6}.ingredient-input-row{grid-gap:.75rem;align-items:flex-end;display:grid;gap:.75rem;grid-template-columns:1fr .6fr .45fr auto}.ingredient-name-group{margin-bottom:0}.ingredient-name-group input{height:36px}.ingredient-quantity-group{margin-bottom:0}.ingredient-quantity-group input{height:36px}.ingredient-unit-group{margin-bottom:0}.ingredient-unit-group select{height:36px;min-height:36px}.btn-add-ingredient-inline{align-items:center;background-color:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;height:36px;justify-content:center;padding:.5rem 1rem;transition:all .2s;white-space:nowrap}.btn-add-ingredient-inline:hover:not(:disabled){background-color:#45a049;box-shadow:0 2px 4px rgba(0,0,0,.2)}.btn-add-ingredient-inline:disabled{cursor:not-allowed;opacity:.6}.ingredients-form{margin-bottom:1.5rem}.ingredients-form,.section-ingredient-form{background-color:#f9f9f9;border:1px solid #eee;border-radius:6px;padding:1.25rem}.section-ingredient-form{margin-bottom:1rem}@media (max-width:768px){.ingredient-input-row{gap:.75rem;grid-template-columns:1fr}.ingredient-name-group,.ingredient-quantity-group,.ingredient-unit-group{margin-bottom:0}.btn-add-ingredient-inline{width:100%}.ingredient-category-row{grid-template-columns:1fr}}.equipment-input-row{display:flex;gap:.75rem;margin-bottom:1rem}.equipment-input-row input{border:1px solid #ddd;border-radius:4px;flex:1 1;font-family:inherit;font-size:1rem;padding:.5rem .75rem;transition:border-color .3s}.equipment-input-row input:focus{border-color:#ff6b6b;box-shadow:0 0 0 3px hsla(0,100%,71%,.1);outline:none}.btn-add-equipment{background-color:#607d8b;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:.5rem 1rem;transition:all .2s;white-space:nowrap}.btn-add-equipment:hover:not(:disabled){background-color:#546e7a;box-shadow:0 2px 4px rgba(0,0,0,.2)}.btn-add-equipment:disabled{cursor:not-allowed;opacity:.5}.equipment-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.equipment-badge{align-items:center;background-color:#eceff1;border:1px solid #cfd8dc;border-radius:20px;color:#37474f;display:inline-flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.4rem .75rem}.btn-remove-equipment{background:none;border:none;color:#78909c;cursor:pointer;font-size:1rem;line-height:1;padding:0;transition:color .2s}.btn-remove-equipment:hover{color:#d32f2f}.ingredient-edit-row{grid-gap:.5rem;align-items:center;display:grid;gap:.5rem;grid-template-columns:1fr 80px 90px auto auto;width:100%}.ingredient-edit-name,.ingredient-edit-qty,.ingredient-edit-unit{border:2px solid #ff6b6b;border-radius:4px;font-family:inherit;font-size:.9rem;padding:.4rem .5rem}.ingredient-edit-name:focus,.ingredient-edit-qty:focus,.ingredient-edit-unit:focus{box-shadow:0 0 0 3px hsla(0,100%,71%,.2);outline:none}.btn-cancel-ingredient,.btn-save-ingredient{align-items:center;background:none;border:1px solid #ddd;border-radius:4px;cursor:pointer;display:flex;font-size:1rem;height:32px;justify-content:center;padding:.3rem .5rem;transition:all .2s;width:32px}.btn-save-ingredient{background-color:#e8f5e9;border-color:#c8e6c9;color:#2e7d32}.btn-save-ingredient:hover{background-color:#c8e6c9}.btn-cancel-ingredient{background-color:#fce4ec;border-color:#ffcdd2;color:#c62828}.btn-cancel-ingredient:hover{background-color:#ffcdd2}.ingredient-actions{align-items:center;display:flex;flex-shrink:0;gap:.35rem}.btn-edit-ingredient{background:none;border:1px solid transparent;border-radius:4px;cursor:pointer;font-size:.85rem;opacity:.5;padding:.25rem .4rem;transition:all .2s}.ingredient-item:hover .btn-edit-ingredient{opacity:1}.btn-edit-ingredient:hover{background-color:#fff3e0;border-color:#ffe0b2}@media (max-width:768px){.equipment-input-row{flex-direction:column}.ingredient-edit-row{gap:.5rem;grid-template-columns:1fr}.ingredient-edit-row .btn-cancel-ingredient,.ingredient-edit-row .btn-save-ingredient{width:100%}}[data-theme=dark] .create-recipe-card{background:var(--bg-card);box-shadow:var(--shadow-md)}[data-theme=dark] .create-recipe-card h1{color:var(--text-primary)}[data-theme=dark] .error-banner{background-color:var(--error-bg);border-left-color:var(--error-border);color:var(--error-color)}[data-theme=dark] .form-group label{color:var(--text-primary)}[data-theme=dark] .form-group input,[data-theme=dark] .form-group select,[data-theme=dark] .form-group textarea{background-color:var(--bg-input);border-color:var(--border-strong);color:var(--text-primary)}[data-theme=dark] .form-group input:disabled,[data-theme=dark] .form-group select:disabled,[data-theme=dark] .form-group textarea:disabled{background-color:var(--bg-card-alt)}[data-theme=dark] .field-help{color:var(--text-faint)}[data-theme=dark] .btn-cancel,[data-theme=dark] .image-preview{border-color:var(--border-strong)}[data-theme=dark] .btn-cancel{background-color:var(--bg-card-alt);color:var(--text-primary)}[data-theme=dark] .btn-cancel:hover:not(:disabled){background-color:var(--border)}[data-theme=dark] .btn-back{border-color:var(--accent);color:var(--accent)}[data-theme=dark] .btn-back:hover{background-color:var(--accent-light)}[data-theme=dark] .form-section-divider{border-top-color:var(--border-faint)}[data-theme=dark] .form-section-divider h2{color:var(--text-primary)}[data-theme=dark] .section-help{color:var(--text-muted)}[data-theme=dark] .add-section-form,[data-theme=dark] .ingredients-form,[data-theme=dark] .sections-list{background-color:var(--form-section-bg);border-color:var(--form-section-border)}[data-theme=dark] .sections-list h3{color:var(--text-primary)}[data-theme=dark] .section-badge{background-color:var(--section-badge-bg);color:var(--section-badge-color)}[data-theme=dark] .section-input-group input{background-color:var(--bg-input);border-color:var(--border-strong);color:var(--text-primary)}[data-theme=dark] .btn-toggle-ingredient-form{background-color:var(--bg-card-alt);border-color:var(--border-strong);color:var(--text-primary)}[data-theme=dark] .btn-toggle-ingredient-form:hover:not(:disabled){background-color:var(--border)}[data-theme=dark] .ingredients-list{background-color:var(--form-section-bg);border-color:var(--form-section-border)}[data-theme=dark] .ingredients-list h3{color:var(--text-primary)}[data-theme=dark] .ingredient-item{background:var(--bg-card);border-color:var(--border)}[data-theme=dark] .ingredient-info:hover{background-color:var(--bg-card-hover)}[data-theme=dark] .ingredient-info strong{color:var(--text-primary)}[data-theme=dark] .section-block{background-color:var(--form-section-bg)}[data-theme=dark] .section-subsection{background-color:var(--bg-card);border-color:var(--border)}[data-theme=dark] .section-subsection h4{border-bottom-color:var(--border);color:var(--text-primary)}[data-theme=dark] .empty-state{color:var(--text-muted)}[data-theme=dark] .section-ingredient-form{background-color:var(--form-section-bg);border-color:var(--form-section-border)}[data-theme=dark] .btn-toggle-section-ingredient-form{background-color:var(--bg-card);border-color:var(--border-strong);color:var(--text-primary)}[data-theme=dark] .btn-toggle-section-ingredient-form:hover:not(:disabled){background-color:var(--bg-card-hover);border-color:var(--text-muted)}[data-theme=dark] .step-input-group{background-color:var(--form-section-bg);border-color:var(--border)}[data-theme=dark] .equipment-input-row input,[data-theme=dark] .step-input-group input{background-color:var(--bg-input);border-color:var(--border-strong);color:var(--text-primary)}[data-theme=dark] .equipment-badge{background-color:var(--equip-bg);border-color:var(--equip-border);color:var(--equip-color)}[data-theme=dark] .btn-remove,[data-theme=dark] .btn-remove-step{background-color:var(--error-bg);border-color:var(--difficulty-hard-bg);color:var(--error-color)}[data-theme=dark] .btn-move-section{background-color:var(--section-badge-bg);border-color:var(--tag-cuisine-bg);color:var(--section-badge-color)}[data-theme=dark] .btn-move-section:disabled{background-color:var(--bg-card-alt);border-color:var(--border);color:var(--text-muted)}[data-theme=dark] .ingredient-edit-name,[data-theme=dark] .ingredient-edit-qty,[data-theme=dark] .ingredient-edit-unit{background-color:var(--bg-input);color:var(--text-primary)}[data-theme=dark] .btn-save-ingredient{background-color:var(--difficulty-easy-bg);border-color:var(--difficulty-easy-bg);color:var(--difficulty-easy-color)}[data-theme=dark] .btn-cancel-ingredient{background-color:var(--difficulty-hard-bg);border-color:var(--difficulty-hard-bg);color:var(--difficulty-hard-color)}.explore-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.explore-header h2{color:#333;font-size:1.75rem;margin:0}.explore-subtitle{color:#888;font-size:.95rem;margin:.25rem 0 0}.sort-controls{align-items:center;display:flex;gap:.5rem}.sort-controls label{color:#666;font-size:.9rem;white-space:nowrap}.sort-select{background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:.9rem;padding:.5rem .75rem;transition:border-color .2s}.sort-select:focus{border-color:#ff6b6b;outline:none}.explore-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.explore-card{background:#fff;border:1px solid #eee;border-radius:8px;box-shadow:0 1px 4px rgba(0,0,0,.08);cursor:pointer;display:flex;flex-direction:column;overflow:hidden;position:relative;transition:all .2s}.explore-card:hover{border-color:#ddd;box-shadow:0 4px 12px rgba(0,0,0,.12);transform:translateY(-2px)}.explore-card:focus{outline:2px solid #ff6b6b;outline-offset:2px}.card-header-badges{align-items:center;display:flex;flex-shrink:0;gap:.4rem}.rank-badge{border-radius:10px;color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.3px;padding:.2rem .5rem;white-space:nowrap}.rank-1{background:linear-gradient(135deg,gold,#fa0)}.rank-2{background:linear-gradient(135deg,silver,#a0a0a0)}.rank-3{background:linear-gradient(135deg,#cd7f32,#b06820)}.explore-card .card-image{background-color:#f5f5f5;height:160px;overflow:hidden;width:100%}.explore-card .card-image img{height:100%;object-fit:cover;transition:transform .3s;width:100%}.explore-card:hover .card-image img{transform:scale(1.05)}.explore-card .card-content{display:flex;flex:1 1;flex-direction:column;padding:1.25rem}.explore-card .card-header{align-items:flex-start;display:flex;gap:.75rem;justify-content:space-between;margin-bottom:.5rem}.explore-card .card-header h3{color:#333;flex:1 1;font-size:1.15rem;line-height:1.3;margin:0}.explore-card .card-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#666;display:-webkit-box;font-size:.9rem;line-height:1.4;margin:.5rem 0;overflow:hidden}.explore-card .card-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.explore-card .card-footer{align-items:center;border-top:1px solid #f0f0f0;color:#999;display:flex;font-size:.85rem;gap:.5rem;justify-content:space-between;margin-top:auto;padding-top:.75rem}@media (max-width:768px){.explore-header{flex-direction:column}.explore-grid{grid-template-columns:1fr}}[data-theme=dark] .explore-header h2{color:var(--text-primary)}[data-theme=dark] .explore-subtitle{color:var(--text-faint)}[data-theme=dark] .sort-controls label{color:var(--text-secondary)}[data-theme=dark] .sort-select{background:var(--bg-input);border-color:var(--border-strong);color:var(--text-primary)}[data-theme=dark] .explore-card{background:var(--bg-card);border-color:var(--border);box-shadow:var(--shadow-sm)}[data-theme=dark] .explore-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-lg)}[data-theme=dark] .explore-card .card-image{background-color:var(--bg-card-alt)}[data-theme=dark] .explore-card .card-header h3{color:var(--text-primary)}[data-theme=dark] .explore-card .card-description{color:var(--text-secondary)}[data-theme=dark] .explore-card .card-footer{border-top-color:var(--border-faint);color:var(--text-muted)}[data-theme=dark] .explore-card .card-tags .tag-cuisine{background-color:var(--tag-cuisine-bg);color:var(--tag-cuisine-color)}[data-theme=dark] .explore-card .card-tags .tag-meal-type{background-color:var(--tag-meal-bg);color:var(--tag-meal-color)}[data-theme=dark] .explore-card .btn-like{color:var(--text-muted)}[data-theme=dark] .explore-card .btn-like:hover{background-color:var(--fav-hover-bg)}[data-theme=dark] .explore-card .btn-like.liked{color:var(--fav-color)}[data-theme=dark] .explore-card .btn-bookmark{border-color:var(--border-strong);color:var(--text-muted)}[data-theme=dark] .explore-card .btn-bookmark.bookmarked,[data-theme=dark] .explore-card .btn-bookmark:hover{background-color:rgba(30,60,120,.25);border-color:#64b5f6;color:#64b5f6}.load-more-row{display:flex;justify-content:center;padding:1.5rem 0 2rem}.btn-load-more{background:transparent;border:1.5px solid var(--primary);border-radius:8px;color:var(--primary);cursor:pointer;font-size:.95rem;font-weight:600;padding:.6rem 2rem;transition:background .15s,color .15s}.btn-load-more:hover:not(:disabled){background:var(--primary);color:#fff}.btn-load-more:disabled{cursor:default;opacity:.6}.shopping-list-page{margin:0 auto;max-width:900px}.sl-header{margin-bottom:1.5rem}.sl-header h2{color:#333;font-size:1.75rem;margin:0 0 .25rem}.sl-subtitle{align-items:center;color:#888;display:flex;flex-wrap:wrap;font-size:.95rem;gap:.5rem;margin:0}.sl-header-row{align-items:flex-start;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between}.sl-header-actions{display:flex;flex-shrink:0;gap:.5rem}.sl-recipe-tag{background:#fff3e0;border-radius:4px;color:#e65100;display:inline-block;font-size:.8rem;font-weight:500;padding:.2rem .6rem}.sl-search,.sl-tabs{margin-bottom:1rem}.sl-tabs{display:flex;gap:.5rem}.sl-tab{background:#fff;border:1px solid #ddd;border-radius:20px;color:#666;cursor:pointer;font-size:.85rem;font-weight:500;padding:.45rem 1rem;transition:all .2s}.sl-tab:hover{border-color:#ff6b6b;color:#ff6b6b}.sl-tab.active{background:#ff6b6b;border-color:#ff6b6b;color:#fff}.sl-search-input{border:1px solid #ddd;border-radius:6px;box-sizing:border-box;font-size:.95rem;padding:.7rem 1rem;transition:border-color .2s,box-shadow .2s;width:100%}.sl-search-input:focus{border-color:#ff6b6b;box-shadow:0 0 0 3px hsla(0,100%,71%,.1);outline:none}.sl-recipe-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:5rem}.sl-recipe-card{align-items:center;background:#fff;border:2px solid #eee;border-radius:8px;cursor:pointer;display:flex;gap:.75rem;padding:.75rem;position:relative;transition:all .2s;-webkit-user-select:none;user-select:none}.sl-recipe-card:hover{border-color:#ddd;box-shadow:0 2px 8px rgba(0,0,0,.06)}.sl-recipe-card.selected{background:#f1f8e9;border-color:#4caf50}.sl-recipe-card:focus{outline:2px solid #ff6b6b;outline-offset:2px}.sl-card-check{align-items:center;border:2px solid #ddd;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.8rem;font-weight:700;height:1.5rem;justify-content:center;transition:all .2s;width:1.5rem}.sl-recipe-card.selected .sl-card-check{background:#4caf50;border-color:#4caf50}.sl-card-image{border-radius:6px;flex-shrink:0;height:50px;overflow:hidden;width:50px}.sl-card-image img{height:100%;object-fit:cover;width:100%}.sl-card-info{flex:1 1;min-width:0}.sl-card-info h4{color:#333;font-size:.95rem;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sl-card-meta{color:#999;font-size:.8rem}.sl-multiplier{display:flex;flex-shrink:0;gap:.2rem}.btn-mult{align-items:center;background:#fff;border:1px solid #ccc;border-radius:3px;color:#777;cursor:pointer;display:flex;font-size:.7rem;font-weight:600;height:1.5rem;justify-content:center;padding:0;transition:all .15s;width:1.75rem}.btn-mult:hover{border-color:#4caf50;color:#4caf50}.btn-mult.active{background:#4caf50;border-color:#4caf50;color:#fff}.sl-footer{align-items:center;background:#fff;border-top:1px solid #eee;bottom:0;box-shadow:0 -2px 8px rgba(0,0,0,.06);display:flex;justify-content:space-between;left:0;padding:.75rem 2rem;position:fixed;right:0;z-index:50}.sl-selected-count{color:#555;font-size:.95rem;font-weight:500}.btn-generate{background:#4caf50;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:.65rem 1.5rem;transition:all .2s}.btn-generate:hover:not(:disabled){background:#45a049;box-shadow:0 2px 8px rgba(76,175,80,.3)}.btn-generate:disabled{cursor:not-allowed;opacity:.5}.btn-sl-action{border:none;border-radius:5px;cursor:pointer;font-size:.85rem;font-weight:500;padding:.45rem 1rem;transition:all .15s}.btn-sl-primary{background:#ff6b6b;color:#fff}.btn-sl-primary:hover{background:#ff5252}.btn-sl-secondary{background:#f0f0f0;border:1px solid #ddd;color:#555}.btn-sl-secondary:hover{background:#e0e0e0}.sl-progress{align-items:center;background:#fff;border:1px solid #eee;border-radius:8px;box-shadow:0 1px 4px rgba(0,0,0,.06);display:flex;gap:.75rem;margin-bottom:1.5rem;padding:.75rem 1rem}.sl-progress-bar{background:#eee;border-radius:4px;flex:1 1;height:8px;overflow:hidden}.sl-progress-fill{background:#4caf50;border-radius:4px;height:100%;transition:width .3s ease}.sl-progress-text{color:#888;font-size:.85rem;font-weight:500;white-space:nowrap}[data-theme=dark] .sl-header h2{color:var(--text-primary)}[data-theme=dark] .sl-subtitle{color:var(--text-faint)}[data-theme=dark] .sl-recipe-tag{background:var(--sl-tag-bg);color:var(--sl-tag-color)}[data-theme=dark] .sl-search-input{background-color:var(--bg-input);border-color:var(--border-strong);color:var(--text-primary)}[data-theme=dark] .sl-tab{background:var(--bg-card);border-color:var(--border-strong);color:var(--text-secondary)}[data-theme=dark] .sl-tab:hover{border-color:var(--accent);color:var(--accent)}[data-theme=dark] .sl-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}[data-theme=dark] .sl-recipe-card{background:var(--bg-card);border-color:var(--border)}[data-theme=dark] .sl-recipe-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}[data-theme=dark] .sl-recipe-card.selected{background:var(--sl-selected-bg);border-color:var(--sl-selected-border)}[data-theme=dark] .sl-card-check{border-color:var(--border-strong)}[data-theme=dark] .sl-card-info h4{color:var(--text-primary)}[data-theme=dark] .sl-card-meta{color:var(--text-muted)}[data-theme=dark] .btn-mult{background:var(--bg-card);border-color:var(--border-strong);color:var(--text-faint)}[data-theme=dark] .sl-footer{background:var(--bg-card);border-top-color:var(--border);box-shadow:0 -2px 8px rgba(0,0,0,.3)}[data-theme=dark] .sl-selected-count{color:var(--text-secondary)}[data-theme=dark] .btn-sl-secondary{background:var(--bg-card-alt);border-color:var(--border-strong);color:var(--text-secondary)}[data-theme=dark] .btn-sl-secondary:hover{background:var(--border)}[data-theme=dark] .sl-progress{background:var(--bg-card);border-color:var(--border);box-shadow:var(--shadow-sm)}[data-theme=dark] .sl-progress-bar{background:var(--border)}[data-theme=dark] .sl-progress-text{color:var(--text-faint)}[data-theme=dark] .sl-category-title{color:var(--text-secondary)}[data-theme=dark] .sl-items{background:var(--bg-card);border-color:var(--border)}[data-theme=dark] .sl-item{border-bottom-color:var(--border-faint)}[data-theme=dark] .sl-item:hover{background:var(--bg-card-hover)}[data-theme=dark] .sl-item.checked{background:var(--bg-card-alt)}[data-theme=dark] .sl-item.checked .sl-item-name,[data-theme=dark] .sl-item.checked .sl-item-qty{color:var(--text-muted)}[data-theme=dark] .sl-item-check{color:var(--border-strong)}[data-theme=dark] .sl-item-name{color:var(--text-primary)}[data-theme=dark] .sl-item-qty{color:var(--text-secondary)}[data-theme=dark] .sl-item-recipes{color:var(--text-muted)}.sl-category{margin-bottom:1.25rem}.sl-category-title{border-bottom:2px solid #ff6b6b;color:#555;font-size:1rem;font-weight:600;margin:0 0 .5rem;padding-bottom:.4rem;text-transform:capitalize}.sl-items{background:#fff;border:1px solid #eee;border-radius:8px;list-style:none;margin:0;overflow:hidden;padding:0}.sl-item{grid-gap:.75rem;align-items:center;border-bottom:1px solid #f5f5f5;cursor:pointer;display:grid;gap:.75rem;grid-template-columns:1.5rem 1fr auto auto;padding:.6rem 1rem;transition:background .15s;-webkit-user-select:none;user-select:none}.sl-item:last-child{border-bottom:none}.sl-item:hover{background:#fafafa}.sl-item.checked{background:#f9f9f9}.sl-item.checked .sl-item-name,.sl-item.checked .sl-item-qty{color:#bbb;text-decoration:line-through}.sl-item-check{color:#ccc;font-size:1rem;transition:color .15s}.sl-item.checked .sl-item-check{color:#4caf50}.sl-item-name{color:#333;font-size:.95rem;font-weight:500}.sl-item-qty{color:#666;font-size:.85rem;text-align:right;white-space:nowrap}.sl-item-recipes{color:#aaa;font-size:.75rem;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media print{.navbar,.sl-footer,.sl-header-actions,.sl-progress,.sl-search{display:none!important}.shopping-list-page{max-width:100%}.sl-item{border-bottom:1px solid #ddd;padding:.3rem 0}.sl-item.checked .sl-item-name,.sl-item.checked .sl-item-qty{text-decoration:line-through}.sl-items{border:none}.sl-category-title{border-bottom:1px solid #333;font-size:.9rem}.sl-recipe-tag{background:none;border:1px solid #ccc;color:#333}}@media (max-width:768px){.sl-recipe-grid{grid-template-columns:1fr}.sl-header-row{flex-direction:column}.sl-item{gap:.5rem;grid-template-columns:1.5rem 1fr auto}.sl-item-recipes{display:none}.sl-footer{padding:.75rem 1rem}}.meal-planner-page{margin:0 auto;max-width:1100px}.mp-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.mp-header h2{color:#333;font-size:1.75rem;margin:0}.mp-week-nav{gap:.5rem}.mp-nav-btn,.mp-week-nav{align-items:center;display:flex}.mp-nav-btn{background:#fff;border:1px solid #ddd;border-radius:50%;cursor:pointer;font-size:1rem;height:2rem;justify-content:center;transition:all .15s;width:2rem}.mp-nav-btn:hover{border-color:#ff6b6b;color:#ff6b6b}.mp-week-label{color:#444;font-size:1rem;font-weight:600;min-width:160px;text-align:center}.mp-today-btn{background:#fff;border:1px solid #ddd;border-radius:4px;color:#555;cursor:pointer;font-size:.8rem;font-weight:500;padding:.3rem .8rem;transition:all .15s}.mp-today-btn:hover{background:#ff6b6b;border-color:#ff6b6b;color:#fff}.mp-grid{grid-gap:1px;background:#e0e0e0;border:1px solid #e0e0e0;border-radius:8px;display:grid;gap:1px;grid-template-columns:80px repeat(7,1fr);overflow:hidden}.mp-corner{background:#f5f5f5;padding:.5rem}.mp-day-header{background:#f5f5f5;color:#555;font-size:.85rem;font-weight:700;padding:.6rem .3rem;text-align:center;text-transform:uppercase}.mp-day-header.today{background:#fff3e0;color:#e65100}.mp-slot-label{align-items:flex-start;background:#f5f5f5;color:#777;display:flex;font-size:.8rem;font-weight:600;padding:.6rem .5rem;text-transform:capitalize}.mp-cell{background:#fff;display:flex;flex-direction:column;gap:.3rem;min-height:70px;padding:.4rem}.mp-cell.today-col{background:#fffde7}.mp-meal-chip{align-items:center;background:#e8f5e9;border-radius:4px;display:flex;font-size:.75rem;gap:.3rem;padding:.25rem .35rem;transition:background .15s}.mp-meal-chip:hover{background:#c8e6c9}.mp-meal-img{border-radius:3px;flex-shrink:0;height:22px;object-fit:cover;width:22px}.mp-meal-name{color:#333;flex:1 1;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mp-meal-remove{background:none;border:none;color:#999;cursor:pointer;flex-shrink:0;font-size:.9rem;line-height:1;padding:0 2px}.mp-meal-remove:hover{color:#e53935}.mp-add-btn{background:transparent;border:1px dashed #ccc;border-radius:4px;color:#bbb;cursor:pointer;font-size:1rem;margin-top:auto;padding:.15rem;transition:all .15s}.mp-add-btn:hover{background:#fff5f5;border-color:#ff6b6b;color:#ff6b6b}.mp-modal-overlay{align-items:center;background:rgba(0,0,0,.4);display:flex;inset:0;justify-content:center;position:fixed;z-index:100}.mp-modal{background:#fff;border-radius:10px;box-shadow:0 8px 30px rgba(0,0,0,.15);display:flex;flex-direction:column;max-height:70vh;width:420px}.mp-modal-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:1rem 1.25rem}.mp-modal-header h3{color:#333;font-size:1.05rem;margin:0;text-transform:capitalize}.mp-modal-close{background:none;border:none;color:#999;cursor:pointer;font-size:1.4rem}.mp-modal-close:hover{color:#333}.mp-modal-tabs{display:flex;gap:.5rem;padding:.75rem 1.25rem 0}.mp-mtab{background:#fff;border:1px solid #ddd;border-radius:16px;color:#666;cursor:pointer;font-size:.8rem;padding:.3rem .75rem;transition:all .15s}.mp-mtab:hover{border-color:#ff6b6b;color:#ff6b6b}.mp-mtab.active{background:#ff6b6b;border-color:#ff6b6b;color:#fff}.mp-modal-search{border:1px solid #ddd;border-radius:6px;font-size:.9rem;margin:.75rem 1.25rem;padding:.55rem .8rem}.mp-modal-search:focus{border-color:#ff6b6b;box-shadow:0 0 0 3px hsla(0,100%,71%,.1);outline:none}.mp-modal-list{flex:1 1;overflow-y:auto;padding:0 1.25rem 1rem}.mp-empty{color:#999;padding:2rem 0;text-align:center}.mp-pick-card{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:.6rem;padding:.55rem .5rem;transition:background .15s}.mp-pick-card:hover{background:#f5f5f5}.mp-pick-img{border-radius:5px;flex-shrink:0;height:38px;object-fit:cover;width:38px}.mp-pick-info{flex:1 1;min-width:0}.mp-pick-name{color:#333;display:block;font-size:.9rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mp-pick-meta{color:#999;font-size:.75rem}[data-theme=dark] .mp-header h2{color:var(--text-primary)}[data-theme=dark] .mp-nav-btn{background:var(--bg-card);border-color:var(--border-strong);color:var(--text-secondary)}[data-theme=dark] .mp-nav-btn:hover{border-color:var(--accent);color:var(--accent)}[data-theme=dark] .mp-week-label{color:var(--text-primary)}[data-theme=dark] .mp-today-btn{background:var(--bg-card);border-color:var(--border-strong);color:var(--text-secondary)}[data-theme=dark] .mp-today-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}[data-theme=dark] .mp-grid{background:var(--border);border-color:var(--border)}[data-theme=dark] .mp-corner,[data-theme=dark] .mp-day-header,[data-theme=dark] .mp-slot-label{background:var(--bg-card-alt)}[data-theme=dark] .mp-day-header{color:var(--text-secondary)}[data-theme=dark] .mp-day-header.today{background:#3e2723;color:#ffab40}[data-theme=dark] .mp-slot-label{color:var(--text-muted)}[data-theme=dark] .mp-cell{background:var(--bg-card)}[data-theme=dark] .mp-cell.today-col{background:#1a1a2e}[data-theme=dark] .mp-meal-chip{background:rgba(76,175,80,.15)}[data-theme=dark] .mp-meal-chip:hover{background:rgba(76,175,80,.25)}[data-theme=dark] .mp-meal-name{color:var(--text-primary)}[data-theme=dark] .mp-meal-remove{color:var(--text-muted)}[data-theme=dark] .mp-add-btn{border-color:var(--border-strong);color:var(--text-muted)}[data-theme=dark] .mp-add-btn:hover{background:hsla(0,100%,71%,.08);border-color:var(--accent);color:var(--accent)}[data-theme=dark] .mp-modal{background:var(--bg-surface);box-shadow:0 8px 30px rgba(0,0,0,.4)}[data-theme=dark] .mp-modal-header{border-bottom-color:var(--border)}[data-theme=dark] .mp-modal-header h3{color:var(--text-primary)}[data-theme=dark] .mp-modal-close{color:var(--text-muted)}[data-theme=dark] .mp-mtab{background:var(--bg-card);border-color:var(--border-strong);color:var(--text-secondary)}[data-theme=dark] .mp-mtab:hover{border-color:var(--accent);color:var(--accent)}[data-theme=dark] .mp-mtab.active{background:var(--accent);border-color:var(--accent);color:#fff}[data-theme=dark] .mp-modal-search{background:var(--bg-input);border-color:var(--border-strong);color:var(--text-primary)}[data-theme=dark] .mp-pick-card:hover{background:var(--bg-card-hover)}[data-theme=dark] .mp-pick-name{color:var(--text-primary)}[data-theme=dark] .mp-pick-meta{color:var(--text-muted)}@media print{.mp-add-btn,.mp-week-nav,.navbar{display:none!important}.mp-grid{border:1px solid #999}.mp-meal-remove{display:none}}@media (max-width:768px){.mp-grid{font-size:.8rem;grid-template-columns:60px repeat(7,1fr)}.mp-cell{min-height:50px;padding:.25rem}.mp-meal-img{display:none}.mp-modal{max-height:80vh;width:95%}}.app{background-color:var(--bg-primary);display:flex;flex-direction:column;min-height:100vh;transition:background-color .3s}.navbar{align-items:center;background-color:#ff6b6b;box-shadow:0 2px 8px rgba(0,0,0,.15);color:#fff;display:flex;justify-content:space-between;padding:.75rem 2rem;position:sticky;top:0;z-index:100}.navbar .navbar-brand{color:#fff;cursor:pointer;font-size:1.4rem;font-weight:700;letter-spacing:.5px;margin:0;text-decoration:none}.navbar .navbar-brand:hover{opacity:.9}.navbar-links{align-items:center;display:flex;gap:1rem}.nav-link{border-radius:4px;color:hsla(0,0%,100%,.85);font-size:.9rem;font-weight:500;padding:.3rem .5rem;text-decoration:none;transition:all .2s}.nav-link:hover{background-color:hsla(0,0%,100%,.15);color:#fff}.navbar h1{cursor:pointer;font-size:1.4rem;margin:0}.navbar button{background-color:hsla(0,0%,100%,.2);border:1px solid hsla(0,0%,100%,.3);border-radius:4px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:500;padding:.4rem 1rem;transition:all .2s}.navbar button:hover{background-color:hsla(0,0%,100%,.3);border-color:hsla(0,0%,100%,.5)}.btn-theme-toggle{align-items:center;background:hsla(0,0%,100%,.15)!important;border:1px solid hsla(0,0%,100%,.25)!important;border-radius:50%!important;cursor:pointer;display:flex;font-size:1.1rem;height:34px;justify-content:center;padding:0!important;transition:all .2s;width:34px}.btn-theme-toggle:hover{background:hsla(0,0%,100%,.3)!important;transform:scale(1.1)}.container{box-sizing:border-box;flex:1 1;margin:0 auto;max-width:1200px;padding:1.5rem 2rem;width:100%}@media (max-width:768px){.navbar{padding:.75rem 1rem}.container{padding:1rem}}
/*# sourceMappingURL=main.0a7b89c1.css.map*/