:root{--bg:#faf8f4;--surface:#fff;--surface-warm:#fef6ee;--surface-muted:#f5f1eb;--text:#2d1f0e;--muted:#5c4835;--primary:#c75b2a;--primary-dark:#a34520;--primary-light:#fdf0e8;--accent-green:#4d7a52;--accent-green-bg:#edf5ee;--accent-yellow:#c49a1a;--accent-yellow-bg:#fdf8e6;--accent-blue:#3a6fa8;--accent-blue-bg:#edf3fc;--accent-red:#b42318;--accent-red-bg:#fde8e6;--border:#e4d9cc;--border-strong:#c9b89f;--shadow-sm:0 1px 3px #2d1f0e0f,0 2px 8px #2d1f0e0a;--shadow:0 4px 16px #2d1f0e14,0 1px 4px #2d1f0e0d;--shadow-lg:0 8px 32px #2d1f0e1a,0 2px 8px #2d1f0e0f;--radius-sm:6px;--radius:10px;--radius-lg:14px;--radius-pill:999px}*{box-sizing:border-box}body{background:#faf8f4;background:var(--bg);color:#2d1f0e;color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;margin:0}button,input,select,textarea{font:inherit}button{background:#f5f1eb;background:var(--surface-muted);border:0;border-radius:999px;border-radius:var(--radius-pill);color:#2d1f0e;color:var(--text);cursor:pointer;font-size:.875rem;font-weight:600;padding:.55rem 1rem;transition:background .15s ease,transform .1s ease,box-shadow .15s ease}button:hover{background:#ede4d8;box-shadow:0 1px 3px #2d1f0e0f,0 2px 8px #2d1f0e0a;box-shadow:var(--shadow-sm);transform:translateY(-1px)}button:active{transform:translateY(0)}button.active,button.primary{background:#c75b2a;background:var(--primary);box-shadow:0 2px 8px #c75b2a4d;color:#fff}button.active:hover,button.primary:hover{background:#a34520;background:var(--primary-dark);box-shadow:0 4px 12px #c75b2a66}button.danger{background:#fde8e6;background:var(--accent-red-bg);color:#b42318;color:var(--accent-red)}button.danger:hover{background:#fbd5d2}button.icon-btn{background:#0000;border:1px solid #e4d9cc;border:1px solid var(--border);font-size:1rem;line-height:1;padding:.45rem .65rem}button.icon-btn:hover{background:#fef6ee;background:var(--surface-warm);border-color:#c75b2a;border-color:var(--primary)}input,select,textarea{background:#fff;border:1.5px solid #e4d9cc;border:1.5px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);color:#2d1f0e;color:var(--text);outline:none;padding:.7rem .85rem;transition:border-color .15s ease,box-shadow .15s ease;width:100%}input:focus,select:focus,textarea:focus{border-color:#c75b2a;border-color:var(--primary);box-shadow:0 0 0 3px #c75b2a1f}textarea{min-height:7rem;resize:vertical}label{grid-gap:.35rem;color:#5c4835;color:var(--muted);display:grid;font-size:.85rem;font-weight:700;gap:.35rem;letter-spacing:.02em;text-transform:uppercase}label input,label select,label textarea{color:#2d1f0e;color:var(--text);font-size:1rem;font-weight:400;letter-spacing:0;text-transform:none}.app-shell{margin:0 auto;padding:1.25rem 0 5rem;width:min(1440px,calc(100% - 2rem))}.app-footer{color:#5c4835;color:var(--muted);font-size:.75rem;opacity:.6;padding:1.5rem 0 2rem;text-align:center}@media (max-width:640px){.app-footer{display:none}}.hero{align-items:center;background:linear-gradient(135deg,#fff7f0,#fdecd9 50%,#fae0c4);border:1px solid #f0d9bc;border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 4px 16px #2d1f0e14,0 1px 4px #2d1f0e0d;box-shadow:var(--shadow);display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem;padding:1rem 1.5rem}.eyebrow{color:#c75b2a;color:var(--primary);font-size:1rem;font-weight:900;letter-spacing:.04em;margin:0}.hero-card{align-items:center;background:#fffc;border:1px solid #c75b2a33;border-radius:999px;border-radius:var(--radius-pill);box-shadow:0 1px 3px #2d1f0e0f,0 2px 8px #2d1f0e0a;box-shadow:var(--shadow-sm);display:flex;flex-wrap:wrap;font-size:.9rem;gap:.75rem;padding:.4rem .9rem .4rem 1rem}.hero-card strong{color:#2d1f0e;color:var(--text)}.tabs{background:#fff;border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #2d1f0e0f,0 2px 8px #2d1f0e0a;box-shadow:var(--shadow-sm);justify-content:space-between;margin-bottom:1rem;padding:.6rem;position:-webkit-sticky;position:sticky;top:0;z-index:10}.tabs,.tabs-links{align-items:center;display:flex;gap:.4rem}.tabs-links{flex:1 1;min-width:0;overflow-x:auto;scrollbar-width:none}.tabs-links::-webkit-scrollbar{display:none}.tabs-user{align-items:center;border-left:1px solid #e4d9cc;border-left:1px solid var(--border);display:flex;flex-shrink:0;gap:.4rem;margin-left:.25rem;padding-left:.5rem}.tabs-user-icon{flex-shrink:0;height:1.2rem;width:1.2rem}.tabs-user-icon,.tabs-user-name{color:#5c4835;color:var(--muted)}.tabs-user-name{font-size:.8rem;font-weight:600;white-space:nowrap}.tabs-logout{background:none;border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:999px;border-radius:var(--radius-pill);box-shadow:none;color:#5c4835;color:var(--muted);font-size:.78rem;padding:.3rem .65rem;white-space:nowrap}.tabs-logout:hover{background:none;border-color:#2d1f0e;border-color:var(--text);box-shadow:none;color:#2d1f0e;color:var(--text);transform:none}.tabs button{align-items:center;background:#0000;border:1.5px solid #0000;border-radius:999px;border-radius:var(--radius-pill);color:#5c4835;color:var(--muted);display:flex;flex-shrink:0;font-size:.875rem;font-weight:600;gap:.4rem;padding:.5rem 1rem}.tab-icon{flex-shrink:0;height:1.1rem;width:1.1rem}.tabs button:hover{background:#fef6ee;background:var(--surface-warm);border-color:#e4d9cc;border-color:var(--border);box-shadow:none;color:#2d1f0e;color:var(--text);transform:none}.tabs button.active{background:#c75b2a;background:var(--primary);border-color:#0000;box-shadow:0 2px 8px #c75b2a59;color:#fff}.tabs button.active:hover{background:#a34520;background:var(--primary-dark)}.toast-container{bottom:1.75rem;display:flex;flex-direction:column;gap:.5rem;pointer-events:none;position:fixed;right:1.75rem;z-index:1100}.toast{align-items:center;animation:toast-in .25s cubic-bezier(.22,1,.36,1) forwards;background:#2b2b2b;border-radius:10px;border-radius:var(--radius);box-shadow:0 4px 16px #0000002e;color:#f5f5f5;display:flex;font-size:.875rem;font-weight:500;gap:.75rem;max-width:380px;min-width:220px;padding:.75rem .75rem .75rem 1rem;pointer-events:all}.toast.toast-exit{animation:toast-out .3s ease forwards}.toast-message{flex:1 1;line-height:1.4}.toast-close{align-items:center;background:none;border:none;border-radius:6px;border-radius:var(--radius-sm);color:#ffffff8c;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:.2rem;transition:color .15s,background .15s}.toast-close svg{height:1rem;width:1rem}.toast-close:hover{background:#ffffff1a;color:#fff}@keyframes toast-in{0%{opacity:0;transform:translateX(1.5rem)}to{opacity:1;transform:translateX(0)}}@keyframes toast-out{0%{margin-bottom:0;max-height:80px;opacity:1;transform:translateX(0)}to{margin-bottom:-.5rem;max-height:0;opacity:0;transform:translateX(1.5rem)}}.grid-layout{grid-gap:1rem;align-items:start;display:grid;gap:1rem;grid-template-columns:minmax(0,1.1fr) minmax(360px,.9fr)}.panel,.sub-panel{background:#fff;border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 4px 16px #2d1f0e14,0 1px 4px #2d1f0e0d;box-shadow:var(--shadow);padding:1.4rem}.sub-panel{background:#f5f1eb;background:var(--surface-muted);border-color:#e4d9cc;border-color:var(--border);box-shadow:none}.sticky-detail{position:-webkit-sticky;position:sticky;top:5.5rem}.detail-image{border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 2px 12px #0000001a;margin-bottom:1.5rem;overflow:hidden;position:relative}.detail-image img{display:block;height:240px;object-fit:cover;width:100%}.detail-image:after{background:linear-gradient(180deg,#0000,#00000014);bottom:0;content:"";height:40%;left:0;pointer-events:none;position:absolute;right:0}.recipe-source-link{border-bottom:1px dashed #c9b89f;border-bottom:1px dashed var(--border-strong);color:#5c4835;color:var(--muted);display:inline-block;font-size:.8rem;margin-top:1.25rem;text-decoration:none}.recipe-source-link:hover{border-bottom-color:#c75b2a;border-bottom-color:var(--primary);color:#c75b2a;color:var(--primary)}.panel-heading{align-items:flex-start;border-bottom:1px solid #e4d9cc;border-bottom:1px solid var(--border);display:flex;gap:1rem;justify-content:space-between;margin-bottom:1.25rem;padding-bottom:1rem}.panel-heading h2,.panel-heading h3{color:#2d1f0e;color:var(--text);font-size:1.25rem;margin:0}.panel-heading p{color:#5c4835;color:var(--muted);font-size:.9rem;margin:.25rem 0 0}.filters-shell{margin-bottom:1.25rem}.filters-bar{align-items:center;display:flex;gap:.6rem;margin-bottom:0}.filters-search-label{color:inherit;display:block;flex:1 1;font-weight:400;gap:0;letter-spacing:0;text-transform:none}.filters-toggle{align-items:center;background:#f5f1eb;background:var(--surface-muted);border:1.5px solid #e4d9cc;border:1.5px solid var(--border);border-radius:999px;border-radius:var(--radius-pill);color:#5c4835;color:var(--muted);display:flex;flex-shrink:0;font-size:.875rem;font-weight:600;gap:.4rem;padding:.55rem 1rem;position:relative}.filters-toggle:hover{color:#2d1f0e;color:var(--text)}.filters-toggle.active,.filters-toggle:hover{border-color:#c75b2a;border-color:var(--primary)}.filters-toggle.active{background:#c75b2a;background:var(--primary);box-shadow:0 2px 8px #c75b2a4d;color:#fff}.filters-toggle.has-active:not(.active){border-color:#c75b2a;border-color:var(--primary);color:#c75b2a;color:var(--primary)}.filters-dot{background:#c75b2a;background:var(--primary);border-radius:50%;height:.45rem;position:absolute;right:.3rem;top:.3rem;width:.45rem}.filters,.form-grid{grid-gap:.9rem;background:#f5f1eb;background:var(--surface-muted);border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);display:grid;gap:.9rem;grid-template-columns:repeat(2,minmax(0,1fr));margin-top:.6rem;padding:1rem}.checkbox{align-items:center;align-self:end;display:flex;flex-direction:row;gap:.6rem}.checkbox input{width:auto}.card-list{grid-gap:.7rem;display:grid;gap:.7rem}.create-form-box{background:#fef6ee;background:var(--surface-warm);border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);margin-bottom:1.25rem;padding:1rem 1.1rem 1.1rem}.create-form-box .form-grid{margin-bottom:.75rem}.ingredient-generate-row{border-top:1px dashed #e4d9cc;border-top:1px dashed var(--border);margin-top:.9rem;padding-top:.9rem}.ingredient-generate-label{color:#5c4835;color:var(--muted);display:block;font-size:.8rem;font-weight:600;margin-bottom:.5rem}.ingredient-generate-controls{display:flex;gap:.5rem}.ingredient-generate-controls input{flex:1 1;min-width:0}.create-form-box button:not(.primary){background:#fff;border:1.5px solid #c9b89f;border:1.5px solid var(--border-strong)}.create-form-box button:not(.primary):hover{background:#fff;border-color:#c75b2a;border-color:var(--primary)}.card-list-section{border-top:1px solid #e4d9cc;border-top:1px solid var(--border);padding-top:1.1rem}.card-list-section.no-top-border{border-top:none;padding-top:0}.card-list-section-label{color:#5c4835;color:var(--muted);font-size:.72rem;font-weight:700;letter-spacing:.07em;margin-bottom:.6rem;text-transform:uppercase}.recipe-card{grid-gap:0;align-items:stretch;background:#fff;border:1.5px solid #e4d9cc;border:1.5px solid var(--border);border-radius:10px;border-radius:var(--radius);cursor:pointer;display:grid;gap:0;grid-template-columns:auto 1fr auto;overflow:hidden;padding:0;position:relative;transition:border-color .15s ease,box-shadow .15s ease,transform .1s ease}.recipe-card-thumb{border-radius:10px 0 0 10px;border-radius:var(--radius) 0 0 var(--radius);flex-shrink:0;overflow:hidden;width:120px}.recipe-card-thumb img{display:block;height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.recipe-card:hover .recipe-card-thumb img{transform:scale(1.04)}.recipe-card-thumb--placeholder{align-items:center;background:#f5f1eb;background:var(--surface-muted);display:flex;justify-content:center}.recipe-card-thumb-icon{color:#e4d9cc;color:var(--border);height:2rem;width:2rem}.recipe-card-body{min-width:0;padding:.85rem 1rem}.recipe-card-description{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.recipe-card:before{background:#0000;border-radius:10px 0 0 10px;border-radius:var(--radius) 0 0 var(--radius);bottom:0;content:"";left:0;position:absolute;top:0;transition:background .15s ease;width:4px}.recipe-card:hover{border-color:#c75b2a;border-color:var(--primary);box-shadow:0 4px 16px #2d1f0e14,0 1px 4px #2d1f0e0d;box-shadow:var(--shadow);transform:translateY(-1px)}.recipe-card:hover:before{background:#c75b2a;background:var(--primary)}.recipe-card.selected{background:#fdf0e8;background:var(--primary-light);border-color:#c75b2a;border-color:var(--primary);box-shadow:0 4px 16px #2d1f0e14,0 1px 4px #2d1f0e0d;box-shadow:var(--shadow)}.recipe-card.selected:before{background:#c75b2a;background:var(--primary)}.recipe-card.selected .card-actions .card-action-icon:not(.danger-icon){background:#fff;border:1.5px solid #c9b89f;border:1.5px solid var(--border-strong)}.recipe-card.selected .card-actions .card-action-icon:not(.danger-icon):hover{background:#fff;border-color:#c75b2a;border-color:var(--primary)}.recipe-card h3{color:#2d1f0e;color:var(--text);font-size:1rem;margin:0 0 .3rem}.recipe-card p{color:#5c4835;color:var(--muted);font-size:.875rem;line-height:1.4;margin:0 0 .65rem}.card-actions{align-items:center;display:flex;gap:.25rem;justify-content:flex-end}.recipe-card .card-actions{align-items:flex-start;padding:.85rem .75rem .85rem 0}.card-action-icon{align-items:center;background:none;border:none;border-radius:6px;border-radius:var(--radius-sm);box-shadow:none;color:#5c4835;color:var(--muted);cursor:pointer;display:flex;justify-content:center;line-height:0;padding:.3rem}.card-action-icon svg{height:1rem;width:1rem}.card-action-icon-star-filled{color:#c75b2a;color:var(--primary);height:1rem;width:1rem}.card-action-icon:hover{background:#f5f1eb;background:var(--surface-muted);box-shadow:none;color:#2d1f0e;color:var(--text);transform:none}.card-action-icon.danger-icon:hover{background:color-mix(in srgb,var(--danger) 8%,#0000);color:var(--danger)}.badges,.button-row,.labels{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:flex-start;margin-top:.5rem}.badges span{border:1.5px solid #0000;border-radius:999px;border-radius:var(--radius-pill);font-size:.78rem;font-weight:700;letter-spacing:.01em;padding:.25rem .65rem}.badges span:first-child{background:#fdf8e6;background:var(--accent-yellow-bg);border-color:#c49a1a;color:#6b4c00}.badges span:nth-child(2){background:#edf3fc;background:var(--accent-blue-bg);border-color:#7aaad8;color:#1e4a8a}.badges span:nth-child(3){background:#edf5ee;background:var(--accent-green-bg);border-color:#7aad80;color:#2a4f2e}.badges span:nth-child(4){background:#f5f1eb;background:var(--surface-muted);border-color:#c9b89f;border-color:var(--border-strong);color:#3d2e20}.badge-icon{display:inline-block;height:.72rem;margin-right:.2rem;margin-top:-.1rem;opacity:.75;vertical-align:middle;width:.72rem}.labels span{background:#edf5ee;background:var(--accent-green-bg);border-radius:999px;border-radius:var(--radius-pill);color:#4d7a52;color:var(--accent-green);font-size:.78rem;font-weight:700;padding:.25rem .65rem}.recipe-form{grid-gap:1.25rem;display:grid;gap:1.25rem;margin-top:1.5rem}.form-section-heading{border-bottom:1px solid #e4d9cc;border-bottom:1px solid var(--border);color:#5c4835;color:var(--muted);font-size:.72rem;font-weight:700;letter-spacing:.06em;margin:.25rem 0 0;padding-bottom:.5rem;text-transform:uppercase}.form-section-heading:first-child{margin-top:0}.recipe-form-footer{align-items:center;display:flex;gap:.75rem}.recipe-form-header-actions{align-items:center;display:flex;flex-shrink:0;gap:.5rem}.recipe-image-placeholder,.recipe-image-upload{display:flex;flex-direction:column}.recipe-image-placeholder{align-items:center;background:#f5f1eb;background:var(--surface-muted);border:2px dashed #e4d9cc;border:2px dashed var(--border);border-radius:10px;border-radius:var(--radius);color:#5c4835;color:var(--muted);cursor:pointer;font-size:.875rem;gap:.5rem;height:220px;justify-content:center;transition:border-color .15s,background .15s}.recipe-image-placeholder:hover{background:#fdf0e8;background:var(--primary-light);border-color:#c75b2a;border-color:var(--primary)}.recipe-image-preview{border:1.5px solid #e4d9cc;border:1.5px solid var(--border);border-radius:10px;border-radius:var(--radius);overflow:hidden;position:relative}.recipe-image-preview img{display:block;height:280px;object-fit:cover;width:100%}.recipe-image-actions{background:#00000073;bottom:0;display:flex;gap:.5rem;left:0;padding:.5rem;position:absolute;right:0}.recipe-image-btn{align-items:center;background:#ffffffe6;border:none;border-radius:6px;border-radius:var(--radius-sm);color:#2d1f0e;color:var(--text);cursor:pointer;display:inline-flex;font-size:.78rem;font-weight:500;gap:.3rem;padding:.3rem .65rem;transition:background .15s}.recipe-image-btn:hover{background:#fff}.recipe-image-btn.danger{background:#ef4444d9;color:#fff}.recipe-image-btn.danger:hover{background:#ef4444}.crop-modal-overlay{align-items:center;background:#000000b8;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1000}.crop-modal{background:#fff;background:var(--surface);border-radius:10px;border-radius:var(--radius);box-shadow:0 8px 32px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:min(640px,100%);overflow:hidden;width:100%}.crop-modal-header{align-items:center;border-bottom:1px solid #e4d9cc;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:1rem 1.25rem .75rem}.crop-modal-header h3{font-size:1rem;font-weight:700;margin:0}.crop-modal-body{align-items:center;background:#f5f1eb;background:var(--surface-muted);display:flex;flex:1 1;justify-content:center;overflow:auto;padding:1rem}.crop-modal-img{display:block;max-height:60vh;max-width:100%}.crop-modal-footer{border-top:1px solid #e4d9cc;border-top:1px solid var(--border);display:flex;gap:.5rem;justify-content:flex-end;padding:.75rem 1.25rem}.recipe-import-url{background:#f5f1eb;background:var(--surface-muted);border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);display:flex;flex-direction:column;gap:.5rem;padding:1rem 1.25rem}.recipe-import-label{color:#5c4835;color:var(--muted);font-size:.8rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.recipe-import-row{align-items:center;display:flex;gap:.5rem}.recipe-import-row input{flex:1 1;min-width:0}.recipe-import-btn{align-items:center;display:inline-flex;flex-shrink:0;gap:.35rem;white-space:nowrap}.recipe-import-error{color:#b42318;color:var(--accent-red);font-size:.82rem;margin:0}.recipe-import-blocked{color:#c49a1a;color:var(--accent-yellow)}.recipe-import-file-btn{white-space:nowrap}.recipe-import-file-section{margin-top:1rem}.profile-divider{border:none;border-top:1px solid #e4d9cc;border-top:1px solid var(--border);margin:1.5rem 0}.profile-section-desc{color:#5c4835;color:var(--muted);font-size:.85rem;line-height:1.5;margin:0 0 1rem}.profile-section-desc a{color:#4d7a52;color:var(--accent-green);text-decoration:none}.profile-section-desc a:hover{text-decoration:underline}.api-key-status-row{align-items:center;display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:.25rem}.api-key-status-set{color:#4d7a52;color:var(--accent-green);font-size:.85rem;font-weight:600}.danger-outline{background:none;border:1px solid #b42318;border:1px solid var(--accent-red);box-shadow:none;color:#b42318;color:var(--accent-red)}.danger-outline:hover{background:#fde8e6;background:var(--accent-red-bg)}.api-key-input-row{align-items:center;display:flex;gap:.5rem}.api-key-input-row input{flex:1 1;font-family:monospace;font-size:.85rem;letter-spacing:.03em}.api-key-save-row{align-items:center;display:flex;gap:.75rem;margin-top:.75rem}.api-key-save-ok{color:#4d7a52;color:var(--accent-green);font-size:.85rem;font-weight:600}.api-key-save-err{color:#b42318;color:var(--accent-red);font-size:.85rem}.form-delete-btn{align-items:center;background:none;border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);box-shadow:none;color:#5c4835;color:var(--muted);cursor:pointer;display:inline-flex;font-size:.82rem;gap:.4rem;padding:.4rem .8rem}.form-delete-btn:hover{background:color-mix(in srgb,var(--danger) 6%,#0000);border-color:var(--danger);box-shadow:none;color:var(--danger);transform:none}.large-textarea{min-height:12rem}.ingredient-row{grid-gap:.6rem;align-items:center;display:grid;gap:.6rem;grid-template-columns:1.4fr .7fr .9fr auto;margin-bottom:.7rem}.ingredient-remove-btn{align-items:center;border:none;color:#9ca3af;color:var(--text-muted,#9ca3af);display:flex;justify-content:center;padding:.3rem}.ingredient-remove-btn:hover{background:#fee2e2;background:var(--danger-bg,#fee2e2);border-color:#0000;color:#dc2626;color:var(--danger,#dc2626)}.add-ingredient-btn{align-items:center;background:#0000;border:1px dashed #e4d9cc;border:1px dashed var(--border,#e5e7eb);border-radius:4px;color:#6b7280;color:var(--text-muted,#6b7280);cursor:pointer;display:flex;font-size:.85rem;gap:.35rem;justify-content:center;margin-top:.25rem;padding:.35rem .6rem;width:100%}.add-ingredient-btn:hover{background:#eff6ff;background:var(--primary-bg,#eff6ff);border-color:#c75b2a;border-color:var(--primary,#2563eb);color:#c75b2a;color:var(--primary,#2563eb)}.ingredient-list{grid-gap:0;display:grid;gap:0;list-style:none;padding:0}.ingredient-list li{grid-gap:.75rem;align-items:baseline;border-bottom:1px solid #e4d9cc;border-bottom:1px solid var(--border);display:grid;font-size:.95rem;gap:.75rem;grid-template-columns:6.5rem 1fr;padding:.5rem 0}.ingredient-list li:last-child{border-bottom:none}.ingredient-amount{color:#c75b2a;color:var(--primary);font-weight:700;text-align:right;white-space:nowrap}.ingredient-name{align-items:baseline;color:#2d1f0e;color:var(--text);display:flex;flex-wrap:wrap;gap:.5rem}.step-list{grid-gap:.75rem;display:grid;gap:.75rem;padding-left:1.4rem}.step-list li{color:#2d1f0e;color:var(--text);line-height:1.6}.details{grid-gap:.6rem;display:grid;gap:.6rem;grid-template-columns:repeat(2,minmax(0,1fr))}.details div{background:#f5f1eb;background:var(--surface-muted);border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);padding:.75rem .9rem}.details dt{color:#5c4835;color:var(--muted);font-size:.78rem;font-weight:800;letter-spacing:.05em;margin-bottom:.2rem;text-transform:uppercase}.details dd{color:#2d1f0e;color:var(--text);font-size:.95rem;font-weight:600;margin:0}.day-list{display:flex;flex-direction:column;gap:.5rem}.day-panel{background:#fff;background:var(--surface);border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);overflow:hidden}.day-panel-header{background:#edf5ee;background:var(--accent-green-bg);border-bottom:1px solid #e4d9cc;border-bottom:1px solid var(--border);color:#4d7a52;color:var(--accent-green);font-size:.78rem;font-weight:800;letter-spacing:.08em;margin:0;padding:.45rem .9rem;text-transform:uppercase}.day-panel-slots{display:flex;flex-direction:column}.meal-slot{grid-gap:.5rem;align-items:center;display:grid;gap:.5rem;grid-template-columns:7rem 1fr;min-height:2.75rem;padding:.55rem .9rem}.meal-slot:not(:last-child){border-bottom:1px solid #e4d9cc;border-bottom:1px solid var(--border)}.meal-slot-label{color:#5c4835;color:var(--muted);flex-shrink:0;font-size:.72rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.meal-slot-filled{align-items:center;display:flex;gap:.5rem;min-width:0}.meal-slot-recipe-title{flex:1 1;font-size:.875rem;min-width:0;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}.meal-slot-servings{align-items:center;color:#5c4835;color:var(--muted);display:flex;flex-shrink:0;font-size:.78rem;font-weight:600;gap:.2rem}.meal-slot-servings input{border-radius:4px;font-size:.8rem;padding:.2rem .3rem;text-align:center;width:2.75rem}.meal-slot-empty select{background:#f5f1eb;background:var(--surface-muted);border:1px dashed #c9b89f;border:1px dashed var(--border-strong);border-radius:6px;border-radius:var(--radius-sm);color:#5c4835;color:var(--muted);font-size:.82rem;max-width:18rem;padding:.3rem .5rem;width:100%}.recipe-link{background:none;border:none;color:#2d1f0e;color:var(--text);cursor:pointer;font:inherit;padding:0;text-decoration:underline;-webkit-text-decoration-color:#c9b89f;text-decoration-color:#c9b89f;-webkit-text-decoration-color:var(--border-strong);text-decoration-color:var(--border-strong);text-underline-offset:2px;transition:color .15s}.recipe-link:hover{color:#c75b2a;color:var(--primary);-webkit-text-decoration-color:#c75b2a;text-decoration-color:#c75b2a;-webkit-text-decoration-color:var(--primary);text-decoration-color:var(--primary)}.shopping-list{list-style:none;margin:0;padding:0}.shopping-item{grid-gap:.75rem;align-items:center;border-bottom:1px solid #e4d9cc;border-bottom:1px solid var(--border);display:grid;font-size:.95rem;gap:.75rem;grid-template-columns:auto 1fr auto;padding:.55rem 0;transition:opacity .15s ease}.shopping-item:last-child{border-bottom:none}.shopping-item-check{align-items:center;display:flex}.shopping-item-check input[type=checkbox]{accent-color:#c75b2a;accent-color:var(--primary);cursor:pointer;height:1.05rem;width:1.05rem}.shopping-item-text{grid-gap:.75rem;align-items:baseline;display:grid;gap:.75rem;grid-template-columns:6.5rem 1fr;min-width:0}.shopping-item.checked .shopping-item-text{opacity:.45;text-decoration:line-through}.shopping-item small{color:#c75b2a;color:var(--primary);display:inline-block;font-size:.78rem;font-weight:700;margin-left:.25rem;text-decoration:none}.panel h2{font-size:1.3rem;margin:0 0 1rem}.panel>h3{border-top:1px solid #e4d9cc;border-top:1px solid var(--border);color:#4d7a52;color:var(--accent-green);font-size:1rem;font-weight:800;margin:1.25rem 0 .6rem;padding-top:1rem}.panel>h3:first-of-type{border-top:0;padding-top:0}.recipe-card.weekmenu-card{grid-template-columns:1fr auto;padding:.75rem 1rem}.recipe-card.weekmenu-card .recipe-card-thumb{display:none}.recipe-card.weekmenu-card .recipe-card-body{padding:0}.recipe-card.weekmenu-card .card-actions{align-items:flex-start;padding:0}@media (max-width:1050px){.grid-layout{grid-template-columns:1fr}.sticky-detail{position:static}}@media (max-width:760px){.app-shell{padding-top:.75rem;width:min(100% - .75rem,1440px)}.hero{border-radius:10px;border-radius:var(--radius);padding:.75rem 1rem}.panel,.sub-panel{padding:1rem}.details,.filters,.form-grid,.ingredient-row,.panel-heading,.recipe-card{grid-template-columns:1fr}.shopping-item-text{grid-template-columns:5rem 1fr}.meal-slot{grid-template-columns:5.5rem 1fr}.card-actions{justify-content:flex-start}}@media (max-width:640px){.tabs{border:none;border-radius:0;border-top:1px solid var(--border);bottom:0;left:0;margin:0;padding:.3rem .25rem max(.3rem,env(safe-area-inset-bottom));position:fixed;right:0;top:auto;width:100%;z-index:200}.tabs-links{gap:0;justify-content:space-around}.tabs-links button{border-radius:10px;border-radius:var(--radius);flex:1 1;flex-direction:column;gap:.15rem;min-height:3rem;min-width:0;padding:.4rem .5rem}.tab-icon{height:1.35rem;width:1.35rem}.tab-label{font-size:.6rem;font-weight:700;letter-spacing:.01em}.tabs-user{display:none}.app-shell{padding-bottom:5.5rem;padding-left:.75rem;padding-right:.75rem;width:100%}.mobile-show-detail .list-panel,.mobile-show-list .detail-panel{display:none}.mobile-back-btn{align-items:center;border:none;color:#c75b2a;color:var(--primary);cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.4rem;padding:0 0 .75rem}.mobile-back-btn,.mobile-back-btn:hover{background:none;box-shadow:none;transform:none}.mobile-back-btn:hover{text-decoration:underline}button,input[type=checkbox],input[type=radio],select{min-height:2.75rem}.card-action-icon,.icon-btn{min-height:2.25rem;min-width:2.25rem}.panel,.sub-panel{border-radius:10px;border-radius:var(--radius)}.recipe-form-footer{background:#fff;background:var(--surface);border-top:1px solid #e4d9cc;border-top:1px solid var(--border);bottom:3.75rem;box-shadow:0 -4px 16px #2d1f0e14;left:0;padding:.625rem 1rem;position:fixed;right:0;z-index:50}.recipe-form{padding-bottom:4.5rem}.recipe-form-header-save{display:none}}@media (min-width:641px){.mobile-back-btn{display:none}}.panel-action-btn{align-items:center;display:inline-flex;gap:.4rem}.btn-icon{flex-shrink:0;height:1rem;width:1rem}@media (max-width:640px){.panel-action-btn{border-radius:50%;flex-shrink:0;height:2.5rem;justify-content:center;padding:0;width:2.5rem}.panel-action-btn .btn-label{display:none}.panel-action-btn .btn-icon{height:1.2rem;width:1.2rem}.panel-action-btn-cancel{background:#f5f1eb;background:var(--surface-muted);border-color:#e4d9cc;border-color:var(--border);box-shadow:none;color:#2d1f0e;color:var(--text)}.panel-action-btn-cancel:hover{background:#fef6ee;background:var(--surface-warm);box-shadow:none;transform:none}}@media print{body{background:#fff}.filters,.hero-card,.tabs,button,input,select,textarea{display:none!important}.app-shell{padding:0;width:100%}.hero,.panel,.recipe-card,.sub-panel{background:#fff;border-color:#ddd;box-shadow:none}.grid-layout{grid-template-columns:1fr}}.home-layout{display:flex;flex-direction:column;gap:1.5rem;margin:0 auto;padding:1.75rem 0 3rem;width:min(100% - 2rem,960px)}.home-welcome h2{color:#2d1f0e;color:var(--text);font-size:1.5rem;font-weight:700;margin:0}.home-quick-actions{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(3,1fr)}.quick-action-btn{align-items:center;background:#fff;background:var(--surface);border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #2d1f0e0f,0 2px 8px #2d1f0e0a;box-shadow:var(--shadow-sm);color:#2d1f0e;color:var(--text);cursor:pointer;display:flex;flex-direction:column;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;padding:1.25rem 1rem;transition:background .15s,box-shadow .15s,transform .1s}.quick-action-btn:hover{background:#fdf0e8;background:var(--primary-light);box-shadow:0 4px 16px #2d1f0e14,0 1px 4px #2d1f0e0d;box-shadow:var(--shadow);transform:translateY(-1px)}.quick-action-icon{color:#c75b2a;color:var(--primary);height:1.75rem;width:1.75rem}.home-two-col{grid-gap:.75rem;align-items:start;display:grid;gap:.75rem;grid-template-columns:3fr 2fr}.home-card{background:#fff;background:var(--surface);border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #2d1f0e0f,0 2px 8px #2d1f0e0a;box-shadow:var(--shadow-sm);padding:1.25rem}.home-card-empty{display:flex;flex-direction:column;gap:.75rem}.home-card-empty p{color:#5c4835;color:var(--muted);font-size:.875rem;margin:0}.home-card--image{cursor:pointer;overflow:hidden;padding:0;transition:box-shadow .15s}.home-card--image:hover{box-shadow:0 4px 16px #2d1f0e14,0 1px 4px #2d1f0e0d;box-shadow:var(--shadow)}.last-viewed-thumb{align-items:center;aspect-ratio:16/7;background:#f5f1eb;background:var(--surface-muted);display:flex;justify-content:center;overflow:hidden;width:100%}.last-viewed-thumb img{display:block;height:100%;object-fit:cover;width:100%}.last-viewed-thumb-icon{color:#e4d9cc;color:var(--border);height:2.5rem;width:2.5rem}.last-viewed-content{padding:1rem 1.25rem 1.25rem}.last-viewed-content .home-card-header{margin-bottom:.6rem}.last-viewed-body{display:flex;flex-direction:column;gap:.3rem}.last-viewed-time{align-items:center;color:#5c4835;color:var(--muted);display:flex;flex-shrink:0;font-size:.78rem;gap:.25rem}.last-viewed-title{color:#2d1f0e;color:var(--text);font-size:1rem;font-weight:700;line-height:1.3}.last-viewed-desc,.last-viewed-title{margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.last-viewed-desc{color:#5c4835;color:var(--muted);font-size:.82rem}.home-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.9rem}.home-card-header h3{color:#4d7a52;color:var(--accent-green);font-size:.95rem;font-weight:800;margin:0}.home-card-icon-btn{align-items:center;background:none;border:none;border-radius:6px;border-radius:var(--radius-sm);box-shadow:none;color:#5c4835;color:var(--muted);cursor:pointer;display:flex;justify-content:center;line-height:0;padding:.2rem}.home-card-icon-btn svg{height:1rem;width:1rem}.home-card-icon-btn:hover{background:#f5f1eb;background:var(--surface-muted);box-shadow:none;color:#c75b2a;color:var(--primary);transform:none}.home-card-more{color:#5c4835;color:var(--muted);font-size:.775rem;margin:.5rem 0 0}.menu-preview-days-list{display:flex;flex-direction:column;gap:.6rem}.menu-preview-day-block{align-items:baseline;display:flex;gap:.75rem}.menu-preview-day-badge{background:#f5f1eb;background:var(--surface-muted);border-radius:999px;border-radius:var(--radius-pill);color:#5c4835;color:var(--muted);flex-shrink:0;font-size:.7rem;font-weight:700;letter-spacing:.05em;padding:.1rem .55rem;text-transform:uppercase;white-space:nowrap}.menu-preview-list{display:flex;flex:1 1;flex-direction:column;gap:.2rem;list-style:none;margin:0;min-width:0;padding:0}.menu-preview-item{align-items:baseline;display:flex;font-size:.825rem;gap:.5rem}.menu-preview-slot{color:#5c4835;color:var(--muted);flex-shrink:0;font-size:.75rem;font-weight:600;min-width:5rem}.menu-preview-title{color:#2d1f0e;color:var(--text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-preview-empty{color:#5c4835;color:var(--muted);font-style:italic}.menu-preview-more{background:none;border:none;border-radius:0;color:#c75b2a;color:var(--primary);cursor:pointer;font-size:.775rem;font-weight:600;margin-top:.1rem;padding:0;text-align:left}.menu-preview-more:hover{background:none;box-shadow:none;text-decoration:underline;transform:none}.shopping-summary{align-items:center;display:flex;gap:.75rem}.shopping-summary-stat{align-items:center;display:flex;flex:1 1;flex-direction:column}.shopping-summary-number{color:#2d1f0e;color:var(--text);font-size:1.5rem;font-weight:700;line-height:1.2}.shopping-summary-label{color:#5c4835;color:var(--muted);font-size:.75rem;text-align:center}.shopping-summary-divider{background:#e4d9cc;background:var(--border);flex-shrink:0;height:2rem;width:1px}.home-section{display:flex;flex-direction:column;gap:.65rem}.home-section-header{align-items:center;display:flex;justify-content:space-between}.home-section-header h3{color:#4d7a52;color:var(--accent-green);font-size:.95rem;font-weight:800;margin:0}.recent-recipes-scroll{grid-gap:.75rem;align-items:start;display:grid;gap:.75rem;grid-template-columns:repeat(4,1fr)}.recent-recipe-card{background:#fff;background:var(--surface);border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);box-shadow:0 1px 3px #2d1f0e0f,0 2px 8px #2d1f0e0a;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:0;min-width:0;padding:0}.recent-recipe-thumb{align-items:center;aspect-ratio:4/3;background:#f5f1eb;background:var(--surface-muted);border-radius:10px 10px 0 0;border-radius:var(--radius) var(--radius) 0 0;display:flex;justify-content:center;overflow:hidden;width:100%}.recent-recipe-thumb img{display:block;height:100%;object-fit:cover;width:100%}.recent-recipe-thumb-icon{color:#e4d9cc;color:var(--border);height:2.25rem;width:2.25rem}.recent-recipe-meta{color:#5c4835;color:var(--muted);font-size:.75rem;font-weight:600;padding:.75rem .85rem 0}.recent-recipe-card h4{font-size:.9rem;font-weight:700;padding:.2rem .85rem 0}.recent-recipe-card h4,.recent-recipe-card p{margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recent-recipe-card p{color:#5c4835;color:var(--muted);font-size:.8rem;padding:.15rem .85rem .85rem}@media (max-width:760px){.home-quick-actions,.home-two-col{grid-template-columns:1fr}.recent-recipes-scroll{grid-template-columns:repeat(2,1fr)}}.recipe-card-title-row{align-items:center;display:flex;gap:.4rem}.recipe-card-title-row h2,.recipe-card-title-row h3{margin:0}.recipe-private-icon{color:#c75b2a;color:var(--primary);flex-shrink:0;height:1rem;width:1rem}.panel-heading .recipe-private-icon{height:1.1rem;width:1.1rem}.visibility-toggle-label{align-items:center;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;-webkit-user-select:none;user-select:none}.visibility-toggle-label input[type=checkbox]{accent-color:#c75b2a;accent-color:var(--primary);cursor:pointer;flex-shrink:0;height:1rem;width:1rem}.visibility-hint{color:#5c4835;color:var(--muted);font-size:.8rem;font-weight:400}.beheer-layout{display:flex;flex-direction:column;gap:0;padding:1.5rem 0 3rem;width:100%}.beheer-heading{margin-bottom:.75rem}.beheer-subtabs{border-bottom:2px solid #e4d9cc;border-bottom:2px solid var(--border);display:flex;gap:0;margin-bottom:1.5rem}.beheer-subtabs button{background:none;border:none;border-bottom:2px solid #0000;border-radius:0;box-shadow:none;color:#5c4835;color:var(--muted);cursor:pointer;font-size:.875rem;font-weight:600;margin-bottom:-2px;padding:.55rem 1.1rem;transition:color .15s,border-color .15s}.beheer-subtabs button:hover{background:none;box-shadow:none;color:#2d1f0e;color:var(--text);transform:none}.beheer-subtabs button.active{border-bottom-color:#c75b2a;border-bottom-color:var(--primary);color:#c75b2a;color:var(--primary)}.beheer-sections,.beheer-subtab-content{display:flex;flex-direction:column;gap:0}.beheer-section{background:#fff;background:var(--surface);border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #2d1f0e0f,0 2px 8px #2d1f0e0a;box-shadow:var(--shadow-sm);margin-bottom:1.25rem;padding:1.5rem}.beheer-section h3{color:#2d1f0e;color:var(--text);font-size:1rem;font-weight:700;margin:0 0 1rem}.beheer-label-list{display:flex;flex-direction:column;gap:.35rem;max-height:320px;overflow-y:auto;padding-right:.25rem}.sharing-add-row{align-items:center;display:flex;gap:.5rem;margin-bottom:1.25rem}.sharing-add-row input{flex:1 1;min-width:0;padding:.45rem .75rem}.sharing-add-row input,.sharing-add-row select{background:#f5f1eb;background:var(--surface-muted);border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);font-size:.875rem}.sharing-add-row select{flex:0 0 auto;padding:.45rem .5rem;width:8rem}.friends-list{display:flex;flex-direction:column;gap:.4rem;list-style:none;margin:0;padding:0}.friends-row{background:#fff;background:var(--surface);border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);overflow:hidden}.friends-row.open{border-color:#c75b2a;border-color:var(--primary)}.friends-row-header{padding:.55rem .55rem .55rem .75rem}.friends-name-btn,.friends-row-header{align-items:center;display:flex;gap:.5rem}.friends-name-btn{background:none;border:none;border-radius:0;box-shadow:none;cursor:pointer;flex:1 1;min-width:0;padding:0;text-align:left}.friends-name-btn:hover{background:none;box-shadow:none;transform:none}.friends-email{color:#2d1f0e;color:var(--text);flex-shrink:1;font-size:.875rem;font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friends-chevron{height:.85rem;width:.85rem}.friends-chevron,.friends-not-sharing{color:#5c4835;color:var(--muted);flex-shrink:0;margin-left:auto}.friends-not-sharing{font-size:.75rem;font-style:italic}.badge-green{background:color-mix(in srgb,#4caf50 15%,#0000);color:#2e7d32}.badge-green,.badge-neutral{border-radius:999px;border-radius:var(--radius-pill);flex-shrink:0;font-size:.7rem;font-weight:700;padding:.15rem .5rem;white-space:nowrap}.badge-neutral{background:#f5f1eb;background:var(--surface-muted);color:#5c4835;color:var(--muted)}.badge-deactivated{background:color-mix(in srgb,#ef4444 12%,#0000);border-radius:999px;border-radius:var(--radius-pill);color:#b91c1c;font-size:.68rem;font-weight:700;margin-left:.4rem;padding:.12rem .45rem;vertical-align:middle;white-space:nowrap}.user-row-actions{align-items:center;display:flex;gap:.15rem}.user-row-actions .icon-btn svg{height:1rem;width:1rem}.user-row--deactivated td{opacity:.6}.user-row--deactivated td:last-child{opacity:1}.friend-sharing-detail{background:#f5f1eb;background:var(--surface-muted);border-top:1px solid #e4d9cc;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.4rem;padding:.75rem 1rem .85rem}.friend-recipe-picker{display:flex;flex-direction:column;gap:.4rem;margin-top:.2rem}.friend-stop-sharing{align-self:flex-start;background:none;border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);box-shadow:none;color:#5c4835;color:var(--muted);cursor:pointer;font-size:.78rem;margin-top:.4rem;padding:.25rem .65rem}.friend-stop-sharing:hover{background:color-mix(in srgb,var(--danger) 6%,#0000);border-color:var(--danger);box-shadow:none;color:var(--danger);transform:none}.sharing-list{display:flex;flex-direction:column;gap:.75rem}.sharing-card{border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);overflow:hidden}.sharing-card-header{align-items:center;background:#f5f1eb;background:var(--surface-muted);border-bottom:1px solid #e4d9cc;border-bottom:1px solid var(--border);display:flex;gap:1rem;justify-content:space-between;padding:.75rem 1rem}.sharing-email{color:#2d1f0e;color:var(--text);flex:1 1;font-size:.875rem;font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sharing-mode-toggle{border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);display:flex;margin:.85rem 1rem 0;overflow:hidden}.sharing-mode-btn{background:none;border:none;border-radius:0;box-shadow:none;color:#5c4835;color:var(--muted);cursor:pointer;flex:1 1;font-size:.82rem;font-weight:600;padding:.45rem .75rem;transition:background .15s,color .15s}.sharing-mode-btn+.sharing-mode-btn{border-left:1px solid #e4d9cc;border-left:1px solid var(--border)}.sharing-mode-btn:hover{background:#f5f1eb;background:var(--surface-muted);box-shadow:none;color:#2d1f0e;color:var(--text);transform:none}.sharing-mode-btn.active,.sharing-mode-btn.active:hover{background:#c75b2a;background:var(--primary);color:#fff}.sharing-mode-hint{color:#5c4835;color:var(--muted);font-size:.78rem;line-height:1.4;margin:.4rem 1rem 0}.sharing-all-edit-note{color:#5c4835;color:var(--muted);font-size:.82rem;margin:.5rem 1rem .85rem}.sharing-select-view{display:flex;flex-direction:column;gap:.4rem;padding:.5rem 1rem .85rem}.sharing-recipe-list{display:flex;flex-direction:column;gap:.3rem;list-style:none;margin:0;padding:0}.sharing-recipe-row{align-items:center;background:#f5f1eb;background:var(--surface-muted);border-radius:6px;border-radius:var(--radius-sm);display:flex;font-size:.825rem;gap:.5rem;justify-content:space-between;padding:.3rem .5rem}.sharing-add-recipe-btn{align-items:center;background:none;border:1px dashed #e4d9cc;border:1px dashed var(--border);border-radius:6px;border-radius:var(--radius-sm);box-shadow:none;color:#5c4835;color:var(--muted);cursor:pointer;display:inline-flex;font-size:.8rem;font-weight:600;gap:.35rem;padding:.4rem .65rem;width:100%}.sharing-add-recipe-btn:hover{background:color-mix(in srgb,#c75b2a 4%,#0000);background:color-mix(in srgb,var(--primary) 4%,#0000);border-color:#c75b2a;border-color:var(--primary);box-shadow:none;color:#c75b2a;color:var(--primary);transform:none}.sharing-picker{background:#fff;background:var(--surface);border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);overflow:hidden}.sharing-picker input{border:none;border-bottom:1px solid #e4d9cc;border-bottom:1px solid var(--border);border-radius:0;font-size:.82rem;padding:.5rem .75rem;width:100%}.sharing-picker-list{list-style:none;margin:0;max-height:12rem;overflow-y:auto;padding:.3rem 0}.sharing-picker-list li button{background:none;border:none;border-radius:0;box-shadow:none;color:#2d1f0e;color:var(--text);display:block;font-size:.82rem;padding:.4rem .75rem;text-align:left;width:100%}.sharing-picker-list li button:hover{background:#f5f1eb;background:var(--surface-muted);box-shadow:none;transform:none}.sharing-picker-empty{color:#5c4835;color:var(--muted);font-size:.8rem;margin:0;padding:.5rem .75rem}button.danger-icon{align-items:center;background:none;border:none;border-radius:6px;border-radius:var(--radius-sm);box-shadow:none;color:#5c4835;color:var(--muted);display:flex;flex-shrink:0;justify-content:center;line-height:0;padding:.2rem}button.danger-icon svg{height:.9rem;width:.9rem}button.danger-icon:hover{background:color-mix(in srgb,var(--danger) 8%,#0000);box-shadow:none;color:var(--danger);transform:none}.label-modal-box{display:flex;flex-direction:column;gap:0;max-width:520px;padding:1.5rem}.label-modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.label-modal-search{margin-bottom:.75rem;position:relative}.label-modal-search-icon{color:#5c4835;color:var(--muted);height:.9rem;left:.65rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);width:.9rem}.label-modal-search input{background:#f5f1eb;background:var(--surface-muted);border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);font-size:.875rem;padding:.45rem .75rem .45rem 2rem;width:100%}.label-modal-list{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.75rem;max-height:340px;overflow-y:auto;padding-right:.25rem}.label-modal-row{grid-gap:.4rem;align-items:center;display:grid;gap:.4rem;grid-template-columns:1fr auto auto}.label-modal-row input{background:#fff;background:var(--surface);border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);font-size:.825rem;padding:.35rem .6rem}.label-modal-row button{font-size:.775rem;padding:.35rem .65rem;white-space:nowrap}.label-modal-row button:disabled{cursor:default;opacity:.4}.label-modal-hint{border-top:1px solid #e4d9cc;border-top:1px solid var(--border);font-size:.775rem;margin:0;padding-top:.5rem}.icon-btn,.label-modal-hint{color:#5c4835;color:var(--muted)}.icon-btn{align-items:center;background:none;border:none;border-radius:6px;border-radius:var(--radius-sm);display:flex;justify-content:center;padding:.3rem}.icon-btn:hover{background:#f5f1eb;background:var(--surface-muted);box-shadow:none;color:#2d1f0e;color:var(--text);transform:none}.dialog-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#2d1f0e80;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1000}.dialog-box{background:#fff;background:var(--surface);border:1px solid #e4d9cc;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 8px 32px #2d1f0e1a,0 2px 8px #2d1f0e0f;box-shadow:var(--shadow-lg);max-width:440px;padding:1.75rem 2rem;width:100%}.dialog-title{color:#2d1f0e;color:var(--text);font-size:1.1rem;font-weight:700;margin:0 0 .5rem}.dialog-message{color:#5c4835;color:var(--muted);font-size:.9rem;line-height:1.55;margin:0 0 1.5rem}.dialog-actions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end}.dialog-actions button{min-width:6.5rem}@keyframes skeleton-shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton-block{animation:skeleton-shimmer 1.4s ease-in-out infinite;background:linear-gradient(90deg,#ece8e3 25%,#f5f1eb 50%,#ece8e3 75%);background-size:800px 100%}.skeleton-list{pointer-events:none}.skeleton-recipe-card{align-items:center;border-bottom:1px solid #e4d9cc;border-bottom:1px solid var(--border,#e5e7eb);display:flex;gap:12px;padding:10px 12px}.skeleton-recipe-card-body{flex:1 1}.skeleton-menu-card{border-bottom:1px solid #e4d9cc;border-bottom:1px solid var(--border,#e5e7eb);padding:12px 16px}.skeleton-name-inline{animation:skeleton-shimmer 1.4s ease-in-out infinite;background:linear-gradient(90deg,#ece8e3 25%,#f5f1eb 50%,#ece8e3 75%);background-size:800px 100%;border-radius:4px;display:inline-block;height:1.2rem;vertical-align:middle;width:7rem}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.pagination{align-items:center;border-top:1px solid #e5e7eb;border-top:1px solid var(--border,#e5e7eb);display:flex;gap:.75rem;justify-content:center;padding:.75rem 1rem}.pagination-btn{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:4px;cursor:pointer;font-size:1rem;padding:.25rem .75rem}.pagination-btn:disabled{cursor:default;opacity:.4}.pagination-info{color:#6b7280;color:var(--text-muted,#6b7280);font-size:.875rem;min-width:3rem;text-align:center}.recipe-search{flex:1 1;position:relative}.recipe-search-input{font-size:.875rem;padding:.375rem .5rem;width:100%}.recipe-search-input,.recipe-search-results{border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:4px}.recipe-search-results{background:#fff;box-shadow:0 4px 16px #00000026;list-style:none;margin:0;max-height:220px;overflow-y:auto;padding:.25rem 0}.recipe-search-results li button{background:none;border:none;cursor:pointer;font-size:.875rem;padding:.5rem .75rem;text-align:left;width:100%}.recipe-search-results li button:hover{background:#f3f4f6;background:var(--bg-hover,#f3f4f6)}.login-page{align-items:center;background:#faf9f7;background:var(--bg-warm,#faf9f7);display:flex;justify-content:center;min-height:100vh;padding:1rem}.login-card{background:#fff;border-radius:12px;box-shadow:0 4px 24px #0000001a;max-width:400px;padding:2rem 2.5rem;width:100%}.login-logo-wrap{display:flex;justify-content:center;margin-bottom:1.75rem}.login-logo{border-radius:16px;height:72px;width:72px}.login-tabs{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border,#e5e7eb);display:flex;margin-bottom:1.5rem}.login-tab{background:none;border:none;border-bottom:2px solid #0000;color:#6b7280;color:var(--text-muted,#6b7280);cursor:pointer;flex:1 1;font-size:.95rem;margin-bottom:-1px;padding:.5rem}.login-tab.active{border-bottom-color:#2563eb;border-bottom-color:var(--primary,#2563eb);color:#2563eb;color:var(--primary,#2563eb);font-weight:600}.login-form{gap:1rem}.login-form,.login-label{display:flex;flex-direction:column}.login-label{font-size:.9rem;font-weight:500;gap:.35rem}.login-input{border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:6px;font-size:.95rem;padding:.6rem .75rem;width:100%}.login-input:focus{border-color:#2563eb;border-color:var(--primary,#2563eb);box-shadow:0 0 0 3px #2563eb1a;outline:none}.login-error{background:#fee2e2;border-radius:6px;color:#dc2626;font-size:.875rem;margin:0;padding:.6rem .75rem}.login-submit{font-size:1rem;padding:.7rem;width:100%}.login-password-wrapper{align-items:center;display:flex;position:relative}.login-password-input{padding-right:2.5rem}.login-password-toggle{align-items:center;background:none;border:none;color:#888;color:var(--muted,#888);cursor:pointer;display:flex;line-height:1;padding:.25rem;position:absolute;right:.6rem}.login-password-toggle:hover{color:#333;color:var(--text,#333)}.users-table{border-collapse:collapse;font-size:.875rem;width:100%}.users-table td,.users-table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border,#e5e7eb);padding:.5rem .75rem;text-align:left;vertical-align:middle}.users-table th{color:#6b7280;color:var(--text-muted,#6b7280);font-size:.8rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.users-table td.center{text-align:center}.add-user-form,.users-table tr.user-row--editing td{background:#faf9f7;background:var(--bg-warm,#faf9f7)}.add-user-form{border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:8px;margin-bottom:1.5rem;padding:1.25rem}.plan-badge{border-radius:99px;display:inline-block;font-size:.75rem;font-weight:600;padding:.2rem .55rem}.plan-badge--free{background:#f3f4f6;color:#6b7280}.plan-badge--subscription{background:#dbeafe;color:#1d4ed8}.plan-badge--lifetime{background:#d1fae5;color:#065f46}.free-plan-notice{background:#fffbeb;border:1px solid #fcd34d;border-radius:8px;color:#92400e;font-size:.9rem;margin-top:.5rem;padding:1rem 1.25rem}@-webkit-keyframes marching-ants{0%{background-position:0 0,0 100%,0 0,100% 0}to{background-position:20px 0,-20px 100%,0 -20px,100% 20px}}@keyframes marching-ants{0%{background-position:0 0,0 100%,0 0,100% 0}to{background-position:20px 0,-20px 100%,0 -20px,100% 20px}}:root{--rc-drag-handle-size:12px;--rc-drag-handle-mobile-size:24px;--rc-drag-handle-bg-colour:#0003;--rc-drag-bar-size:6px;--rc-border-color:#ffffffb3;--rc-focus-color:#08f}.ReactCrop{cursor:crosshair;display:inline-block;max-width:100%;position:relative}.ReactCrop *,.ReactCrop :after,.ReactCrop :before{-webkit-box-sizing:border-box;box-sizing:border-box}.ReactCrop--disabled,.ReactCrop--locked{cursor:inherit}.ReactCrop__child-wrapper{max-height:inherit;overflow:hidden}.ReactCrop__child-wrapper>img,.ReactCrop__child-wrapper>video{display:block;max-height:inherit;max-width:100%}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>img,.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>video,.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__crop-selection{-ms-touch-action:none;touch-action:none}.ReactCrop__crop-mask{bottom:0;height:calc(100% + .5px);left:0;pointer-events:none;position:absolute;right:0;top:0;width:calc(100% + .5px)}.ReactCrop__crop-selection{cursor:move;left:0;position:absolute;top:0;-webkit-transform:translateZ(0);transform:translateZ(0)}.ReactCrop--disabled .ReactCrop__crop-selection{cursor:inherit}.ReactCrop--circular-crop .ReactCrop__crop-selection{border-radius:50%}.ReactCrop--circular-crop .ReactCrop__crop-selection:after{border:1px solid #ffffffb3;border:1px solid var(--rc-border-color);bottom:-1px;content:"";left:-1px;opacity:.3;pointer-events:none;position:absolute;right:-1px;top:-1px}.ReactCrop--no-animate .ReactCrop__crop-selection{outline:1px dashed #fff}.ReactCrop__crop-selection:not(.ReactCrop--no-animate .ReactCrop__crop-selection){-webkit-animation:marching-ants 1s;animation:marching-ants 1s;-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite;-webkit-animation-play-state:running;animation-play-state:running;-webkit-animation-timing-function:linear;animation-timing-function:linear;background-image:-webkit-gradient(linear,left top,right top,color-stop(50%,#fff),color-stop(50%,#444)),-webkit-gradient(linear,left top,right top,color-stop(50%,#fff),color-stop(50%,#444)),-webkit-gradient(linear,left top,left bottom,color-stop(50%,#fff),color-stop(50%,#444)),-webkit-gradient(linear,left top,left bottom,color-stop(50%,#fff),color-stop(50%,#444));background-image:linear-gradient(90deg,#fff 50%,#444 0),linear-gradient(90deg,#fff 50%,#444 0),linear-gradient(180deg,#fff 50%,#444 0),linear-gradient(180deg,#fff 50%,#444 0);background-position:0 0,0 100%,0 0,100% 0;background-repeat:repeat-x,repeat-x,repeat-y,repeat-y;background-size:10px 1px,10px 1px,1px 10px,1px 10px;color:#fff}.ReactCrop__crop-selection:focus{outline:2px solid #08f;outline:2px solid var(--rc-focus-color);outline-offset:-1px}.ReactCrop--invisible-crop .ReactCrop__crop-mask,.ReactCrop--invisible-crop .ReactCrop__crop-selection{display:none}.ReactCrop__rule-of-thirds-hz:after,.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-vt:after,.ReactCrop__rule-of-thirds-vt:before{background-color:#fff6;content:"";display:block;position:absolute}.ReactCrop__rule-of-thirds-vt:after,.ReactCrop__rule-of-thirds-vt:before{height:100%;width:1px}.ReactCrop__rule-of-thirds-vt:before{left:33.3333333333%}.ReactCrop__rule-of-thirds-vt:after{left:66.6666666667%}.ReactCrop__rule-of-thirds-hz:after,.ReactCrop__rule-of-thirds-hz:before{height:1px;width:100%}.ReactCrop__rule-of-thirds-hz:before{top:33.3333333333%}.ReactCrop__rule-of-thirds-hz:after{top:66.6666666667%}.ReactCrop__drag-handle{background-color:#0003;background-color:var(--rc-drag-handle-bg-colour);border:1px solid #ffffffb3;border:1px solid var(--rc-border-color);height:12px;height:var(--rc-drag-handle-size);position:absolute;width:12px;width:var(--rc-drag-handle-size)}.ReactCrop__drag-handle:focus{background:#08f;background:var(--rc-focus-color)}.ReactCrop .ord-nw{cursor:nw-resize;left:0}.ReactCrop .ord-n,.ReactCrop .ord-nw{top:0;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%)}.ReactCrop .ord-n{cursor:n-resize;left:50%}.ReactCrop .ord-ne{cursor:ne-resize;top:0}.ReactCrop .ord-e,.ReactCrop .ord-ne{right:0;-webkit-transform:translate(50%,-50%);transform:translate(50%,-50%)}.ReactCrop .ord-e{cursor:e-resize;top:50%}.ReactCrop .ord-se{bottom:0;cursor:se-resize;right:0;-webkit-transform:translate(50%,50%);transform:translate(50%,50%)}.ReactCrop .ord-s{cursor:s-resize;left:50%}.ReactCrop .ord-s,.ReactCrop .ord-sw{bottom:0;-webkit-transform:translate(-50%,50%);transform:translate(-50%,50%)}.ReactCrop .ord-sw{cursor:sw-resize;left:0}.ReactCrop .ord-w{cursor:w-resize;left:0;top:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%)}.ReactCrop__disabled .ReactCrop__drag-handle{cursor:inherit}.ReactCrop__drag-bar{position:absolute}.ReactCrop__drag-bar.ord-n{height:6px;height:var(--rc-drag-bar-size);left:0;top:0;-webkit-transform:translateY(-50%);transform:translateY(-50%);width:100%}.ReactCrop__drag-bar.ord-e{height:100%;right:0;top:0;-webkit-transform:translate(50%);transform:translate(50%);width:6px;width:var(--rc-drag-bar-size)}.ReactCrop__drag-bar.ord-s{bottom:0;height:6px;height:var(--rc-drag-bar-size);left:0;-webkit-transform:translateY(50%);transform:translateY(50%);width:100%}.ReactCrop__drag-bar.ord-w{height:100%;left:0;top:0;-webkit-transform:translate(-50%);transform:translate(-50%);width:6px;width:var(--rc-drag-bar-size)}.ReactCrop--fixed-aspect .ReactCrop__drag-bar,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-e,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-n,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-s,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-w,.ReactCrop--new-crop .ReactCrop__drag-bar,.ReactCrop--new-crop .ReactCrop__drag-handle{display:none}@media (pointer:coarse){.ReactCrop .ord-e,.ReactCrop .ord-n,.ReactCrop .ord-s,.ReactCrop .ord-w{display:none}.ReactCrop__drag-handle{height:24px;height:var(--rc-drag-handle-mobile-size);width:24px;width:var(--rc-drag-handle-mobile-size)}}