@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=Playfair+Display:ital,wght@0,400;0,700;1,400&display=swap";.notif-bell{display:inline-block;position:relative}.notif-bell-btn{appearance:none;cursor:pointer;font-size:var(--text-lg);color:var(--text-main);transition:background var(--transition);background:0 0;border:none;border-radius:50%;padding:.4rem;line-height:1;position:relative}.notif-bell-btn:hover{background:var(--bg-surface-alt)}.notif-bell-badge{background:var(--terracotta);color:#fff;text-align:center;pointer-events:none;border-radius:999px;min-width:16px;height:16px;padding:0 4px;font-size:.62rem;font-weight:800;line-height:16px;position:absolute;top:0;right:0}.notif-bell-dropdown{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);width:340px;max-width:calc(100vw - 1rem);box-shadow:var(--shadow-md);z-index:1000;position:absolute;top:calc(100% + .5rem);right:0;overflow:hidden}.notif-bell-header{border-bottom:1px solid var(--border-color);background:var(--bg-surface-alt);justify-content:space-between;align-items:center;gap:.5rem;padding:.75rem 1rem;display:flex}.notif-bell-title{font-weight:700;font-size:var(--text-base);color:var(--text-main)}.notif-bell-mark-all{appearance:none;color:var(--terracotta);font-family:inherit;font-size:var(--text-sm);cursor:pointer;background:0 0;border:none;padding:.2rem .4rem;font-weight:700}.notif-bell-mark-all:disabled{color:var(--text-muted);cursor:not-allowed}.notif-bell-empty{text-align:center;color:var(--text-muted);font-size:var(--text-sm);padding:1.5rem 1rem;font-style:italic}.notif-bell-loading{flex-direction:column;gap:.6rem;padding:1rem;display:flex}.notif-bell-skel{border-radius:var(--radius-xs);background:linear-gradient(90deg, var(--sage-alpha-20) 0%, var(--sage-alpha-40) 50%, var(--sage-alpha-20) 100%);background-position:100% 0;background-size:200% 100%;width:90%;height:.85em;animation:1.6s ease-in-out infinite skeleton-shimmer}.notif-bell-skel--short{width:55%}.notif-bell-list{max-height:60vh;margin:0;padding:0;list-style:none;overflow-y:auto}.notif-bell-item{border-bottom:1px solid var(--border-color)}.notif-bell-item:last-child{border-bottom:none}.notif-bell-item-btn{appearance:none;text-align:left;cursor:pointer;width:100%;color:var(--text-main);transition:background var(--transition);background:0 0;border:none;flex-direction:column;gap:.2rem;padding:.7rem 1rem;font-family:inherit;display:flex}.notif-bell-item-btn:hover{background:var(--bg-surface-alt)}.notif-bell-item.is-unread .notif-bell-item-btn{background:color-mix(in srgb, var(--terracotta) 6%, transparent)}.notif-bell-item.is-unread .notif-bell-item-btn:hover{background:color-mix(in srgb, var(--terracotta) 10%, transparent)}.notif-bell-item-title{font-size:var(--text-sm);color:var(--text-main);font-weight:600;line-height:1.35}.notif-bell-item.is-unread .notif-bell-item-title{color:var(--terracotta)}.notif-bell-item-body{font-size:var(--text-sm);color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.35;display:-webkit-box;overflow:hidden}.notif-bell-item-when{font-size:var(--text-xs);color:var(--text-muted);margin-top:.1rem}.notif-bell-footer{border-top:1px solid var(--border-color);background:var(--bg-surface-alt);text-align:center;padding:.5rem 1rem}.notif-bell-view-all{appearance:none;color:var(--text-muted);font-family:inherit;font-size:var(--text-xs);cursor:pointer;border-radius:var(--radius-xs);transition:color var(--transition);background:0 0;border:none;padding:.2rem .4rem;font-weight:600}.notif-bell-view-all:hover{color:var(--text-main)}@media (width<=640px){.notif-bell-dropdown{width:auto;max-height:70vh;position:fixed;top:72px;left:.5rem;right:.5rem}}.input-modal-overlay{background:var(--scrim);z-index:1000;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.input-modal{background:var(--bg-surface);border-radius:var(--radius-md);box-shadow:var(--elevation-modal);flex-direction:column;width:100%;max-width:440px;max-height:calc(100dvh - 2rem);display:flex;overflow:hidden}.input-modal-header{border-bottom:1px solid var(--border-color);flex-shrink:0;padding:1.25rem 1.5rem 1rem;position:relative}.input-modal-header h2{font-family:var(--font-accent);font-size:var(--text-lg);color:var(--text-main);margin:0;padding-right:2rem}.input-modal-close{appearance:none;cursor:pointer;color:var(--text-muted);font-size:var(--text-base);border-radius:var(--radius-sm);transition:var(--transition);background:0 0;border:none;padding:.3rem;line-height:1;position:absolute;top:.75rem;right:.75rem}.input-modal-close:hover{background:var(--bg-surface-alt);color:var(--text-main)}.input-modal-body{flex-direction:column;gap:1rem;padding:1.25rem 1.5rem 1.5rem;display:flex;overflow-y:auto}.input-modal-message{font-size:var(--text-base);color:var(--text-muted);margin:0;line-height:1.5}.input-modal-field{flex-direction:column;gap:.35rem;display:flex}.input-modal-label{font-size:var(--text-sm);color:var(--text-main);font-weight:600}.input-modal-required{color:var(--text-muted);font-style:italic;font-weight:400}.input-modal-input{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-input,var(--bg-surface));width:100%;color:var(--text-main);font-family:inherit;font-size:var(--text-base);resize:vertical;box-sizing:border-box;padding:.5rem .7rem;transition:border-color .15s,box-shadow .15s}.input-modal-input:focus{border-color:var(--terracotta);outline:none;box-shadow:0 0 0 2px #e1705526}.input-modal-error{font-size:var(--text-sm);color:var(--error,#c53030)}.input-modal-counter{font-size:var(--text-xs);color:var(--text-muted);text-align:right}.input-modal-actions{justify-content:flex-end;gap:.6rem;display:flex}.input-modal-cancel,.input-modal-submit{appearance:none;border-radius:var(--radius-sm);font-family:inherit;font-size:var(--text-sm);cursor:pointer;transition:var(--transition);padding:.45rem 1.1rem;font-weight:700}.input-modal-cancel{border:1.5px solid var(--border-color);color:var(--text-muted);background:0 0}.input-modal-cancel:hover{border-color:var(--text-muted);color:var(--text-main)}.input-modal-submit{background:var(--terracotta);border:1.5px solid var(--terracotta);color:#fff}.input-modal-submit:hover:not(:disabled){background:var(--terracotta-hover,#cf6348);border-color:var(--terracotta-hover,#cf6348)}.input-modal-submit:disabled{opacity:.5;cursor:not-allowed}@media (width<=480px){.input-modal{max-width:100%}.input-modal-actions{flex-direction:column-reverse;gap:.5rem}.input-modal-cancel,.input-modal-submit{text-align:center;width:100%}}.toast-container{z-index:50000;pointer-events:none;flex-direction:column;gap:.6rem;max-height:calc(100vh - 4rem);display:flex;position:fixed;top:2rem;right:2rem;overflow:hidden}.toast-notification{background:var(--bg-surface);color:var(--text-main);border-radius:var(--radius-md);box-shadow:var(--elevation-toast);border-left:4px solid var(--terracotta);word-break:break-word;pointer-events:all;align-items:center;gap:.85rem;min-width:280px;max-width:min(440px,100vw - 4rem);padding:.85rem 1.25rem;animation:.4s cubic-bezier(.16,1,.3,1) slideInRight;display:flex}@media (width<=768px){.toast-container{align-items:stretch;top:1rem;left:1rem;right:1rem}.toast-notification{min-width:0;max-width:none}}.toast-notification.success{border-left-color:var(--olive)}.toast-notification.error{border-left-color:var(--error)}.toast-icon{background:var(--bg-surface-alt);width:24px;height:24px;font-weight:800;font-size:var(--text-sm);border-radius:50%;justify-content:center;align-items:center;display:flex}.success .toast-icon{color:var(--olive)}.error .toast-icon{color:var(--error)}.toast-message{font-weight:600;font-size:var(--text-base);-webkit-line-clamp:4;-webkit-box-orient:vertical;flex:1;display:-webkit-box;overflow:hidden}.toast-retry{border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-size:var(--text-sm);font-family:var(--font-main);white-space:nowrap;transition:var(--transition);background:0 0;flex-shrink:0;align-items:center;gap:.3rem;padding:.2rem .5rem;font-weight:600;display:flex}.toast-retry:hover{border-color:var(--border-color-strong);color:var(--text-main)}.toast-close{color:var(--text-muted);cursor:pointer;font-size:var(--text-md);transition:var(--transition);background:0 0;border:none;flex-shrink:0;padding:.25rem}.toast-close:hover{color:var(--text-main)}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)scale(.9)}to{opacity:1;transform:translate(0)scale(1)}}.confirm-overlay{z-index:30050;padding:max(1rem, env(safe-area-inset-top)) max(1rem, env(safe-area-inset-right)) max(1rem, env(safe-area-inset-bottom)) max(1rem, env(safe-area-inset-left));background:var(--scrim);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);justify-content:center;align-items:center;animation:.18s ease-out confirm-overlay-in;display:flex;position:fixed;inset:0}@keyframes confirm-overlay-in{0%{opacity:0}to{opacity:1}}.confirm-dialog{background:var(--bg-surface);border-radius:var(--radius-md);box-shadow:var(--elevation-modal);flex-direction:column;gap:.85rem;width:100%;max-width:420px;padding:1.5rem 1.5rem 1.25rem;animation:.22s cubic-bezier(.175,.885,.32,1.275) confirm-dialog-in;display:flex}@keyframes confirm-dialog-in{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.confirm-dialog.is-destructive{border-top:3px solid var(--error);padding-top:calc(1.5rem - 2px)}.confirm-title{font-family:var(--font-accent);font-size:var(--text-lg);color:var(--text-main);letter-spacing:-.01em;margin:0;font-weight:700;line-height:1.25}.confirm-message{color:var(--text-muted);font-size:var(--text-base);margin:0;line-height:1.5}.confirm-actions{flex-wrap:wrap;justify-content:flex-end;gap:.6rem;margin-top:.5rem;display:flex}.confirm-btn{min-height:40px}@media (width<=480px){.confirm-dialog{padding:1.25rem 1.1rem 1rem}.confirm-actions{flex-direction:column-reverse;align-items:stretch}.confirm-btn{width:100%}}.list-manage-overlay{z-index:30002}.list-manage-modal{max-width:520px}.list-manage-section{margin-bottom:1.5rem}.list-manage-section:last-child{margin-bottom:0}.list-manage-section-label{font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.55rem;font-weight:700;display:block}.list-manage-count{color:var(--text-muted);letter-spacing:0;text-transform:none;margin-left:.4rem;font-weight:600}.list-manage-rename-row{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.list-manage-rename-row .input-modal-input{flex:1;min-width:12rem}.list-manage-name{font-size:var(--text-base);color:var(--text-main);flex:1;font-weight:700}.list-manage-members{flex-direction:column;gap:.4rem;margin:0;padding:0;list-style:none;display:flex}.list-manage-member{border-radius:var(--radius-sm);background:var(--bg-surface-alt);align-items:center;gap:.6rem;padding:.4rem .5rem;display:flex}.list-manage-member-avatar{background:var(--bg-surface);border:1px solid var(--border-color);width:28px;height:28px;color:var(--text-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex;overflow:hidden}.list-manage-member-avatar img{object-fit:cover;width:100%;height:100%}.list-manage-member-name{font-size:var(--text-sm);color:var(--text-main);flex:1;font-weight:600}.list-manage-member-name em{color:var(--text-muted);font-style:normal;font-weight:400}.list-manage-member-tag{font-size:var(--text-2xs);letter-spacing:.04em;text-transform:uppercase;color:var(--terracotta);background:var(--terracotta-tint);border-radius:999px;padding:.1rem .5rem;font-weight:700}.list-manage-member-remove{appearance:none;color:var(--text-muted);font:inherit;font-size:var(--text-xs);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.2rem .5rem;font-weight:600}.list-manage-member-remove:hover{color:var(--error,#c00)}.list-manage-toggle{font-size:var(--text-sm);color:var(--text-main);cursor:pointer;align-items:center;gap:.5rem;display:flex}.list-manage-toggle input[type=checkbox]{cursor:pointer;width:16px;height:16px}.list-manage-help{font-size:var(--text-xs);color:var(--text-muted);margin:.4rem 0 0;line-height:1.4}.list-manage-invites{flex-direction:column;gap:.4rem;margin:0;padding:0;list-style:none;display:flex}.list-manage-invite{border-radius:var(--radius-sm);background:var(--bg-surface-alt);align-items:center;gap:.6rem;padding:.45rem .6rem;display:flex}.list-manage-invite-text{flex-direction:column;flex:1;gap:.1rem;min-width:0;display:flex}.list-manage-invite-target{font-size:var(--text-sm);color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.list-manage-invite-status{font-size:var(--text-xs);color:var(--text-muted)}.list-manage-danger{border-top:1px solid var(--border-color);padding-top:1rem}.list-manage-danger-row{flex-wrap:wrap;gap:.5rem;display:flex}.list-manage-leave{color:var(--text-main)}.list-manage-delete{background:var(--error,#c00)!important;color:#fff!important}.empty-state{text-align:center;padding:var(--space-lg) var(--space-md);justify-content:center;align-items:center;gap:var(--space-xs);color:var(--text-muted);flex-direction:column;display:flex}.empty-state-icon{color:var(--text-muted);opacity:.55;margin-bottom:var(--space-xs);line-height:1}.empty-state-headline{font-family:var(--font-accent);font-size:var(--text-lg);color:var(--text-main);margin:0;font-weight:700;line-height:1.3}.empty-state-body{font-size:var(--text-base);color:var(--text-muted);max-width:34ch;margin:0;line-height:1.55}.empty-state-action{margin-top:var(--space-sm)}.empty-state--compact{padding:var(--space-md) var(--space-sm);gap:.35rem}.empty-state--compact .empty-state-headline{font-size:var(--text-md)}.empty-state--compact .empty-state-body{font-size:var(--text-sm)}.sl-backdrop{background:var(--scrim);z-index:15000;justify-content:center;align-items:flex-end;animation:.18s ease-out sl-backdrop-in;display:flex;position:fixed;inset:0}@keyframes sl-backdrop-in{0%{opacity:0}to{opacity:1}}.sl-panel{background:var(--bg-surface);border-radius:var(--radius-md) var(--radius-md) 0 0;width:100%;max-width:680px;max-height:85vh;box-shadow:var(--shadow-timeline);flex-direction:column;animation:.22s ease-out sl-sheet-up;display:flex;overflow:hidden}@keyframes sl-sheet-up{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@media (width>=600px){.sl-backdrop{align-items:center}.sl-panel{border-radius:var(--radius-sm);width:640px;max-height:80vh}}.sl-backdrop--fullscreen{z-index:30000!important;align-items:stretch!important}.sl-panel--fullscreen{height:100dvh;animation:none;border-radius:0!important;width:100%!important;max-width:100%!important;max-height:100dvh!important}@media (width>=600px){.sl-panel--fullscreen{border-radius:0!important;width:100%!important;max-width:100%!important}}.sl-header{border-bottom:1px solid var(--border-color);flex-shrink:0;padding:.9rem 1.25rem 0}.sl-header-row{align-items:center;gap:.6rem;display:flex}.sl-header-top{justify-content:space-between;margin-bottom:.65rem}.sl-header-tools{flex-wrap:wrap;gap:.5rem;margin-bottom:.65rem}.sl-header-bottom{flex-wrap:wrap;justify-content:space-between;gap:.5rem;padding-bottom:.75rem}.sl-header-left{align-items:center;gap:.6rem;min-width:0;display:flex}.sl-title{font-family:var(--font-accent);font-size:var(--text-lg);color:var(--text-main);font-weight:700}.sl-count{font-size:var(--text-sm);color:var(--text-muted);background:var(--bg-surface-alt);border:1px solid var(--border-color);border-radius:999px;padding:.1rem .55rem;font-weight:700}.sl-mode-trigger{appearance:none;background:var(--bg-surface-alt);border:1px solid var(--border-color);color:var(--text-main);font:inherit;font-size:var(--text-xs);cursor:pointer;white-space:nowrap;text-overflow:ellipsis;border-radius:999px;align-items:center;gap:.3rem;max-width:12rem;padding:.15rem .55rem;font-weight:700;transition:border-color .12s,background .12s,color .12s;display:inline-flex;overflow:hidden}.sl-mode-trigger:hover,.sl-mode-trigger:focus,.sl-mode-trigger[aria-expanded=true]{border-color:var(--accent-sage,#738b6e);color:var(--text-main);outline:none}.sl-mode-caret{font-size:var(--text-2xs);opacity:.65}.sl-mode-popover{min-width:220px}.sl-family-banner{font-size:var(--text-xs);color:var(--text-muted);background:var(--bg-surface-alt);border-bottom:1px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:center;gap:.6rem;padding:.4rem 1.25rem;font-weight:600;display:flex}.sl-presence-chip{background:color-mix(in srgb, var(--sage) 12%, transparent);border:1px solid color-mix(in srgb, var(--sage) 25%, transparent);color:var(--sage);border-radius:var(--radius-pill);font-size:var(--text-2xs);white-space:nowrap;letter-spacing:.01em;animation:sl-presence-in var(--motion-duration-quiet) var(--motion-ease-arrive) both;align-items:center;gap:.25rem;padding:.15rem .55rem;font-weight:700;display:inline-flex}@keyframes sl-presence-in{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.sl-migrate-banner{background:var(--terracotta-tint);border-bottom:1px solid var(--border-color);font-size:var(--text-sm);color:var(--text-main);flex-shrink:0;justify-content:space-between;align-items:center;gap:.6rem;padding:.55rem 1.25rem;display:flex}.sl-migrate-text{text-overflow:ellipsis;min-width:0;overflow:hidden}.sl-migrate-btn{appearance:none;background:var(--terracotta);color:#fff;font:inherit;font-size:var(--text-xs);cursor:pointer;white-space:nowrap;border:none;border-radius:999px;flex-shrink:0;padding:.3rem .75rem;font-weight:700;transition:background .12s,opacity .12s}.sl-migrate-btn:hover:not(:disabled){background:var(--terracotta-hover)}.sl-migrate-btn:disabled{opacity:.6;cursor:not-allowed}.sl-migrate-actions{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.sl-migrate-dismiss{appearance:none;font:inherit;font-size:var(--text-xs);color:var(--text-muted);cursor:pointer;border-radius:var(--radius-xs);white-space:nowrap;transition:color var(--motion-duration-micro) var(--motion-ease-standard), background var(--motion-duration-micro) var(--motion-ease-standard);background:0 0;border:none;padding:.3rem .4rem}.sl-migrate-dismiss:hover:not(:disabled){color:var(--text-main);background:var(--bg-surface-alt)}.sl-migrate-dismiss:disabled{opacity:.5;cursor:not-allowed}.sl-attrib{background:var(--bg-surface-alt);border:1px solid var(--border-color);width:20px;height:20px;color:var(--text-muted);cursor:help;-webkit-user-select:none;user-select:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:10px;font-weight:700;display:inline-flex;overflow:hidden}.sl-attrib img{object-fit:cover;width:100%;height:100%;display:block}.sl-attrib--checked{border-color:var(--accent-sage,#738b6e)}.sl-attrib-initial{text-transform:uppercase;line-height:1}.sl-header-right{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.sl-icon-btn{appearance:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-xs);background:0 0;border:none;justify-content:center;align-items:center;padding:.25rem .35rem;line-height:1;transition:color .12s,background .12s;display:flex}.sl-wakelock-btn{display:none}@media (width<=768px){.sl-wakelock-btn{display:flex}.sl-wakelock-btn.is-active{color:var(--terracotta)}.sl-fullscreen-btn{display:none}}.sl-icon-btn:hover{color:var(--text-main);background:var(--bg-surface-alt)}.sl-close-btn{appearance:none;font-size:var(--text-lg);color:var(--text-muted);cursor:pointer;border-radius:var(--radius-xs);background:0 0;border:none;padding:.2rem .4rem;line-height:1;transition:color .12s}.sl-close-btn:hover{color:var(--text-main)}.sl-view-toggle{border:1px solid var(--border-color);background:var(--bg-surface-alt);border-radius:999px;flex-shrink:0;gap:0;padding:2px;display:flex}.sl-view-btn{appearance:none;font:inherit;font-size:var(--text-xs);color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:999px;padding:.28rem .65rem;font-weight:600;transition:background .14s,color .14s,box-shadow .14s}.sl-view-btn.active{background:var(--bg-surface);color:var(--text-main);box-shadow:0 1px 3px #0000001f}.sl-clear-checked-btn{appearance:none;border:1px solid var(--border-color);color:var(--text-secondary);font:inherit;font-size:var(--text-xs);cursor:pointer;white-space:nowrap;background:0 0;border-radius:999px;padding:.25rem .65rem;font-weight:600;transition:border-color .12s,color .12s}.sl-clear-checked-btn:hover{border-color:var(--accent-sage);color:var(--accent-sage)}.sl-body{flex-direction:column;flex:1;padding:.75rem 0 .5rem;display:flex;overflow-y:auto}.sl-add-form{border-bottom:1px solid var(--border-subtle,#0000000f);grid-template-columns:3.25rem 1fr auto;align-items:center;gap:.4rem;margin-bottom:.5rem;padding:0 1.25rem .75rem;display:grid}.sl-add-form input{appearance:none;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-sm,6px);font:inherit;font-size:var(--text-sm);color:var(--text-main);min-width:0;padding:.4rem .6rem}.sl-add-form input::placeholder{color:var(--text-muted)}.sl-add-form input:focus{border-color:var(--accent-sage,#738b6e);outline:none;box-shadow:0 0 0 2px #738b6e2e}.sl-add-notes{grid-area:2/1/auto/3}@media (width>=480px){.sl-add-form{grid-template-columns:3.25rem minmax(0,1fr) minmax(0,1fr) auto}.sl-add-notes{grid-area:auto}}.sl-add-submit{appearance:none;background:var(--accent-sage,#738b6e);color:#fff;cursor:pointer;border:none;border-radius:999px;grid-row:1;width:32px;height:32px;font-size:1.1rem;font-weight:700;line-height:1;transition:background .12s,opacity .12s}.sl-add-submit:hover:not(:disabled){background:var(--sage-deep,#2d3436)}.sl-add-submit:disabled{opacity:.4;cursor:not-allowed}.sl-item-aisle-trigger{appearance:none;border-radius:var(--radius-xs);color:var(--text-muted);font:inherit;font-size:var(--text-xs);cursor:pointer;white-space:nowrap;text-overflow:ellipsis;opacity:0;background:0 0;border:1px solid #0000;align-items:center;gap:.25rem;max-width:9rem;padding:.15rem .4rem;font-weight:600;transition:opacity .12s,border-color .12s,color .12s,background .12s;display:inline-flex;overflow:hidden}.sl-item:hover .sl-item-aisle-trigger,.sl-item-aisle-trigger:focus,.sl-item-aisle-trigger[aria-expanded=true]{opacity:.85;border-color:var(--border-color)}.sl-item-aisle-trigger:hover,.sl-item-aisle-trigger:focus,.sl-item-aisle-trigger[aria-expanded=true]{opacity:1;color:var(--text-main);border-color:var(--accent-sage,#738b6e);background:var(--bg-surface-alt);outline:none}.sl-item-aisle-caret{font-size:var(--text-2xs);opacity:.7;line-height:1}@media (hover:none){.sl-item-aisle-trigger{opacity:.5}}.sl-aisle-popover{z-index:30001;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-sm,8px);box-shadow:var(--shadow-hover);flex-direction:column;gap:1px;min-width:180px;padding:.3rem;animation:.14s ease-out sl-popover-in;display:flex;position:fixed}@keyframes sl-popover-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.sl-aisle-option{appearance:none;border-radius:var(--radius-xs);font:inherit;font-size:var(--text-sm);color:var(--text-main);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.55rem;padding:.45rem .65rem;transition:background .1s,color .1s;display:flex}.sl-aisle-option:hover,.sl-aisle-option:focus{background:var(--terracotta-tint);color:var(--text-main);outline:none}.sl-aisle-option.active,.sl-aisle-option.active:hover,.sl-aisle-option.active:focus{background:var(--accent-sage,#738b6e);color:var(--text-inverse,#fff)}.sl-aisle-option-emoji{font-size:var(--text-md);flex-shrink:0;line-height:1}.sl-aisle-option-name{white-space:nowrap;flex:1;font-weight:600}.sl-aisle-option-check{flex-shrink:0;font-size:.85rem;font-weight:700}.sl-aisle-option-meta{font-size:var(--text-2xs);color:var(--text-muted);background:var(--bg-surface-alt);border-radius:999px;flex-shrink:0;padding:.05rem .4rem;font-weight:600}.sl-aisle-divider{background:var(--border-color);height:1px;margin:.25rem .4rem}.sl-aisle-option--action{color:var(--terracotta);font-weight:600}.sl-aisle-option--action .sl-aisle-option-name{color:var(--terracotta)}.sl-aisle-option--action:hover,.sl-aisle-option--action:focus{background:var(--terracotta-tint)}.sl-share-list-btn{appearance:none;border:1px solid var(--border-color);color:var(--text-muted);font:inherit;font-size:var(--text-xs);cursor:pointer;background:0 0;border-radius:999px;margin-left:.4rem;padding:.15rem .55rem;font-weight:700;transition:border-color .12s,color .12s,background .12s}.sl-share-list-btn:hover,.sl-share-list-btn:focus{border-color:var(--terracotta);color:var(--terracotta);background:var(--terracotta-tint);outline:none}.sl-share-list-btn:disabled{opacity:.6;cursor:progress}.sl-share-modal{max-width:480px}.sl-share-link{gap:.5rem;margin-top:.5rem;display:flex}.sl-share-link input{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-surface-alt);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:var(--text-xs);color:var(--text-main);text-overflow:ellipsis;flex:1;min-width:0;padding:.5rem .75rem;overflow:hidden}.sl-share-link input:focus{border-color:var(--accent-sage,#738b6e);outline:none}.sl-share-link .btn{flex-shrink:0;min-width:5.5rem}.sl-share-copied{background:var(--accent-sage,#738b6e)!important}.sl-share-or{font-size:var(--text-xs);color:var(--text-muted);text-align:center;text-transform:uppercase;letter-spacing:.06em;margin:1rem 0 .5rem;font-weight:600}.sl-share-email{gap:.5rem;display:flex}.sl-share-email input{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-surface);font-size:var(--text-sm);color:var(--text-main);flex:1;min-width:0;padding:.5rem .75rem}.sl-share-email input:focus{border-color:var(--accent-sage,#738b6e);outline:none}.sl-share-email .btn{flex-shrink:0;min-width:5.5rem}.sl-empty{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:2.5rem 2rem;display:flex}.sl-empty-icon{margin-bottom:.25rem;font-size:2.5rem;line-height:1}.sl-empty p{font-size:var(--text-base);color:var(--text-main);margin:0;font-weight:600}.sl-empty-hint{max-width:280px;line-height:1.5;font-size:var(--text-sm)!important;color:var(--text-muted)!important;font-weight:400!important}.sl-group{margin-bottom:1.1rem;padding:0 1.25rem}.sl-group-header{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.sl-group-title{font-size:var(--text-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--terracotta);white-space:nowrap;text-overflow:ellipsis;min-width:0;font-weight:800;overflow:hidden}.sl-group-remove{appearance:none;color:var(--text-muted);font-size:var(--text-xs);cursor:pointer;background:0 0;border:none;border-radius:3px;flex-shrink:0;padding:.1rem .3rem;transition:color .12s}.sl-group-remove:hover{color:var(--text-main)}.sl-ing-group{margin-bottom:.9rem;padding:0 1.25rem}.sl-ing-name{font-size:var(--text-xs);letter-spacing:.07em;text-transform:uppercase;color:var(--terracotta);border-bottom:1px solid var(--border-subtle,#0000000f);margin-bottom:.15rem;padding-bottom:.25rem;font-weight:800}.sl-merged-source{font-size:var(--text-sm);color:var(--text-muted);margin-left:.25rem;font-style:italic;font-weight:400}.sl-ing-recipe-tag{font-size:var(--text-sm);color:var(--text-muted);font-style:italic}.sl-aisle-section{margin-bottom:1.1rem;padding:0 1.25rem}.sl-aisle-header{border-bottom:1px solid var(--border-subtle,#0000000f);align-items:center;gap:.45rem;margin-bottom:.15rem;padding-bottom:.3rem;display:flex}.sl-aisle-emoji{font-size:var(--text-md);flex-shrink:0;line-height:1}.sl-aisle-name{font-size:var(--text-xs);letter-spacing:.07em;text-transform:uppercase;color:var(--terracotta);flex:1;font-weight:800}.sl-aisle-count{font-size:var(--text-xs);color:var(--text-muted);background:var(--bg-surface-alt);border:1px solid var(--border-color);border-radius:999px;flex-shrink:0;padding:.05rem .4rem;font-weight:600}.sl-notes{color:var(--text-muted);font-style:italic;font-weight:400}.sl-items{flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.sl-item{border-bottom:1px solid var(--border-subtle,#0000000f);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.6rem;padding:.48rem 0;display:flex}.sl-item:last-child{border-bottom:none}.sl-item--checked .sl-name,.sl-item--checked .sl-qty{color:var(--text-muted)}.sl-checkbox{border:2px solid var(--border-color);background:var(--bg-surface);width:20px;height:20px;font-size:var(--text-xs);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:800;transition:background .12s,border-color .12s;display:flex}.sl-item--checked .sl-checkbox{background:var(--accent-sage,#738b6e);border-color:var(--accent-sage,#738b6e)}.sl-qty{font-size:var(--text-sm);color:var(--text-secondary);font-variant-numeric:tabular-nums;flex-shrink:0;min-width:2.5rem;font-weight:700}.sl-qty--btn{appearance:none;border-radius:var(--radius-xs,4px);cursor:text;text-align:left;font:inherit;font-size:var(--text-sm);color:var(--text-secondary);background:0 0;border:1px dashed #0000;padding:.05rem .3rem;font-weight:700;transition:border-color .12s,background .12s,color .12s}.sl-qty--btn:hover,.sl-qty--btn:focus-visible{border-color:var(--border-color);background:var(--bg-surface-alt);color:var(--text-main);outline:none}.sl-qty--empty{color:var(--text-muted);opacity:0;transition:opacity .12s,border-color .12s,background .12s,color .12s}.sl-item:hover .sl-qty--empty,.sl-qty--empty:focus-visible{opacity:.6}@media (hover:none){.sl-qty--empty{opacity:.45}}.sl-qty--editing{appearance:none;background:var(--bg-surface);border:1px solid var(--accent-sage,#738b6e);border-radius:var(--radius-xs,4px);font:inherit;font-size:var(--text-sm);font-variant-numeric:tabular-nums;color:var(--text-main);flex-shrink:0;width:5rem;padding:.05rem .3rem;font-weight:700;box-shadow:0 0 0 2px #738b6e2e}.sl-qty--editing:focus{outline:none}.sl-item--checked .sl-qty--btn:hover{color:var(--text-muted);background:0 0;border-color:#0000}.sl-name{font-size:var(--text-base);color:var(--text-main);flex:1;line-height:1.4}.sl-item-remove{appearance:none;color:var(--text-muted);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;min-width:28px;min-height:28px;padding:.2rem .35rem;font-size:.6rem;line-height:1;transition:opacity .12s,color .12s,background .12s;display:flex}.sl-item:hover .sl-item-remove{opacity:.6}.sl-item-remove:hover{color:var(--text-main);background:var(--bg-surface-alt);opacity:1!important}@media (hover:none){.sl-item-remove{opacity:.45}}.sl-item--checked .sl-item-remove{opacity:.4}.sl-footer{border-top:1px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:center;gap:.5rem;padding:.75rem 1.25rem 1rem;display:flex}.sl-share-btn{appearance:none;border:1px solid var(--border-color);border-radius:var(--radius-sm,6px);color:var(--text-secondary);font:inherit;font-size:var(--text-sm);cursor:pointer;background:0 0;align-items:center;gap:.35rem;padding:.35rem .75rem;font-weight:600;transition:color .12s,border-color .12s,background .12s;display:inline-flex}.sl-share-btn:hover{border-color:var(--accent-sage,#738b6e);color:var(--accent-sage,#738b6e);background:#738b6e12}.sl-share-btn--copied{border-color:var(--accent-sage,#738b6e)!important;color:var(--accent-sage,#738b6e)!important;background:#738b6e14!important}.sl-clear-all-btn{appearance:none;border-radius:var(--radius-sm,6px);color:var(--text-muted);font:inherit;font-size:var(--text-sm);cursor:pointer;background:0 0;border:1px solid #0000;padding:.35rem .65rem;font-weight:600;transition:color .12s,border-color .12s,background .12s}.sl-clear-all-btn:hover{color:var(--error);border-color:var(--error-border);background:var(--error-bg-hover)}[data-theme=dark] .sl-clear-all-btn:hover{color:#f87171;background:#dc26261f;border-color:#dc26264d}@keyframes sl-wipe-out{0%{opacity:1;transform:translate(0)}40%{opacity:.5;transform:translate(12px)}to{opacity:0;transform:translate(48px)}}.sl-body--clearing .sl-group-title,.sl-body--clearing .sl-ing-name,.sl-body--clearing .sl-aisle-header{animation:.28s ease-in forwards sl-wipe-out}.sl-body--clearing .sl-item{animation:.3s ease-in forwards sl-wipe-out;animation-delay:calc(var(--sl-i,0) * 28ms);pointer-events:none}.sl-undo-bar{background:var(--bg-surface-alt);border-top:1px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:center;gap:.75rem;padding:.6rem 1.25rem;animation:.2s ease-out sl-undo-in;display:flex}@keyframes sl-undo-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.sl-undo-msg{font-size:var(--text-sm);color:var(--text-secondary)}.sl-undo-btn{appearance:none;border:1px solid var(--accent-sage,#738b6e);border-radius:var(--radius-sm,6px);color:var(--accent-sage,#738b6e);font:inherit;font-size:var(--text-sm);cursor:pointer;white-space:nowrap;background:0 0;padding:.3rem .75rem;font-weight:700;transition:background .12s,color .12s}.sl-undo-btn:hover{background:#738b6e1f}.sl-trigger-pill{font:inherit;font-size:var(--text-sm);cursor:pointer;border:1px solid var(--border-color);background:var(--bg-surface);color:var(--text-main);white-space:nowrap;border-radius:999px;align-items:center;gap:.4rem;padding:.45rem .9rem;font-weight:600;transition:border-color .15s,color .15s,background .15s;display:inline-flex}.sl-trigger-pill:hover,.sl-trigger-pill.has-items{border-color:var(--accent-sage,#738b6e);color:var(--accent-sage,#738b6e);background:#738b6e14}.sl-item-aisle-emoji{flex-shrink:0;font-size:.95rem;line-height:1}.sl-item-aisle-label{white-space:nowrap;text-overflow:ellipsis;min-width:0;overflow:hidden}@media (width<=480px){.sl-item{gap:.4rem}.sl-group,.sl-ing-group,.sl-aisle-section{padding:0 1rem}.sl-qty,.sl-qty--btn{min-width:2rem}.sl-item-aisle-label{display:none}.sl-item-aisle-trigger{max-width:none;padding-inline:.3rem}}@media (width<=400px){.sl-item{gap:.35rem}.sl-attrib{width:18px;height:18px;font-size:9px}.sl-item-aisle-emoji{font-size:.9rem}}@media (width<=360px){.sl-item{gap:.3rem}.sl-group,.sl-ing-group,.sl-aisle-section{padding:0 .75rem}.sl-attrib{width:16px;height:16px;font-size:8px}.sl-qty,.sl-qty--btn{min-width:1.85rem}}.sl-channel-error{background:color-mix(in srgb, var(--canon-gold,#c8a84b) 14%, transparent);border-top:1px solid color-mix(in srgb, var(--canon-gold,#c8a84b) 35%, transparent);border-bottom:1px solid color-mix(in srgb, var(--canon-gold,#c8a84b) 35%, transparent);font-size:var(--text-xs);color:var(--text-main);padding:.45rem .85rem}.sl-mutation-error{background:color-mix(in srgb, var(--terracotta) 12%, transparent);border-top:1px solid color-mix(in srgb, var(--terracotta) 30%, transparent);border-bottom:1px solid color-mix(in srgb, var(--terracotta) 30%, transparent);font-size:var(--text-xs);color:var(--text-main);justify-content:space-between;align-items:center;gap:.5rem;padding:.45rem .85rem;display:flex}.sl-mutation-error-dismiss{appearance:none;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:3px;flex-shrink:0;padding:.15rem .3rem;font-size:.65rem;line-height:1}.sl-mutation-error-dismiss:hover{color:var(--text-main);background:var(--bg-surface-alt)}.title-earn-overlay{z-index:2000;padding:max(1rem, env(safe-area-inset-top)) max(1rem, env(safe-area-inset-right)) max(1rem, env(safe-area-inset-bottom)) max(1rem, env(safe-area-inset-left));background:var(--scrim);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;pointer-events:none;justify-content:center;align-items:center;transition:opacity .5s ease-out;display:flex;position:fixed;inset:0}.title-earn-overlay.is-visible{opacity:1;pointer-events:auto}.title-earn-stack{flex-direction:column;gap:.75rem;width:calc(100% - 2rem);max-width:380px;display:flex}.title-earn-card{background:var(--bg-surface);border:1px solid var(--terracotta);border-radius:var(--radius-md);text-align:center;box-shadow:0 0 0 4px var(--terracotta-glow), var(--shadow-lg);opacity:0;padding:1.5rem 1.5rem 1.25rem;animation:.9s ease-out both title-earn-bloom}@keyframes title-earn-bloom{0%{opacity:0;transform:translateY(12px)scale(.96)}60%{opacity:1;transform:translateY(-2px)scale(1.02)}to{opacity:1;transform:translateY(0)scale(1)}}.title-earn-eyebrow{font-size:var(--text-xs);letter-spacing:.18em;text-transform:uppercase;color:var(--terracotta);margin-bottom:.6rem;font-weight:800;display:block}.title-earn-icon{font-size:var(--text-display);margin-bottom:.5rem;line-height:1}.title-earn-name{font-family:var(--font-accent);color:var(--text-main);flex-wrap:wrap;justify-content:center;align-items:center;gap:.35em;margin:0 0 .5rem;font-size:1.8rem;line-height:1.15;display:flex}.title-earn-word{opacity:0;animation:title-earn-word-base .5s calc(.3s + var(--word-index,0) * .2s) cubic-bezier(.4, 0, .2, 1) both;display:inline-block}.title-earn-word--left{animation-name:title-earn-word-from-left}.title-earn-word--right{animation-name:title-earn-word-from-right}@keyframes title-earn-word-from-left{0%{opacity:0;transform:translate(-1.5em)}to{opacity:1;transform:translate(0)}}@keyframes title-earn-word-from-right{0%{opacity:0;transform:translate(1.5em)}to{opacity:1;transform:translate(0)}}.title-earn-leaf{opacity:0;font-size:.85em;animation:.55s .85s forwards title-earn-leaf-in;display:inline-block;transform:translateY(.3em)rotate(-20deg)}@keyframes title-earn-leaf-in{0%{opacity:0;transform:translateY(.3em)rotate(-20deg)}60%{opacity:1;transform:translateY(-.05em)rotate(8deg)}to{opacity:1;transform:translateY(0)rotate(0)}}@media (prefers-reduced-motion:reduce){.title-earn-word,.title-earn-leaf{opacity:1;animation:none;transform:none}}.title-earn-description{font-size:var(--text-base);color:var(--text-main);margin:0;font-style:italic;line-height:1.5}.title-earn-unlocks{border-top:1px dashed var(--border-color);font-size:var(--text-sm);color:var(--text-muted);margin:.85rem 0 0;padding-top:.7rem;line-height:1.4}.title-earn-unlocks strong{color:var(--terracotta);letter-spacing:.04em;text-transform:uppercase;font-size:var(--text-xs)}.title-byline{vertical-align:-1px;filter:drop-shadow(0 1px 1px #0000001a);cursor:help;justify-content:center;align-items:center;line-height:1;display:inline-flex}.title-byline-sm{font-size:.9em}.title-byline-md{font-size:1.05em}.title-byline-lg{font-size:1.25em}.milestone-overlay{z-index:30000;background:var(--bg-main);background-image:radial-gradient(circle at 50% 30%, color-mix(in srgb, var(--terracotta) 8%, transparent), transparent 55%);cursor:pointer;-webkit-user-select:none;user-select:none;text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:1rem;animation:.28s ease-out both milestone-overlay-fade-in;display:flex}.milestone-overlay--fixed{position:fixed;inset:0}.milestone-overlay--contained{border-radius:inherit;position:absolute;inset:0;overflow:hidden}.milestone-overlay--closing{animation:.5s ease-in forwards milestone-overlay-fade-out}@keyframes milestone-overlay-fade-in{0%{opacity:0}to{opacity:1}}@keyframes milestone-overlay-fade-out{0%{opacity:1}to{opacity:0;pointer-events:none}}.milestone-overlay-stage{flex-direction:column;align-items:center;gap:.4rem;max-width:min(92%,540px);display:flex;position:relative}.milestone-overlay-icon{opacity:0;font-size:3.4rem;line-height:1;animation:.65s cubic-bezier(.4,0,.2,1) .2s both milestone-overlay-icon-in;transform:scale(.7)}@keyframes milestone-overlay-icon-in{0%{opacity:0;transform:scale(.7)}60%{opacity:1;transform:scale(1.06)}to{opacity:1;transform:scale(1)}}.milestone-overlay-eyebrow{font-family:var(--font-main);font-size:var(--text-xs);letter-spacing:.22em;text-transform:uppercase;color:var(--terracotta);opacity:0;font-weight:800;animation:.55s .45s both milestone-overlay-fade-up}.milestone-overlay-title{font-family:var(--font-accent);color:var(--text-main);letter-spacing:-.01em;opacity:0;margin:.2rem 0 0;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:700;line-height:1.2;animation:.7s cubic-bezier(.4,0,.2,1) .65s both milestone-overlay-title-in}@keyframes milestone-overlay-title-in{0%{opacity:0;transform:translateY(.6em)}to{opacity:1;transform:translateY(0)}}.milestone-overlay-subtitle{font-family:var(--font-accent);color:var(--text-muted);opacity:0;margin:.35rem 0 0;font-size:clamp(.95rem,1.6vw,1.15rem);font-style:italic;line-height:1.45;animation:.6s 1s both milestone-overlay-fade-up}@keyframes milestone-overlay-fade-up{0%{opacity:0;transform:translateY(.4em)}to{opacity:1;transform:translateY(0)}}.milestone-overlay-flourish-leaf{font-size:var(--text-xl);opacity:0;animation:.7s 1.1s forwards milestone-overlay-leaf-in;position:absolute;top:-.5rem;right:-.3rem;transform:translateY(.5em)rotate(-20deg)}@keyframes milestone-overlay-leaf-in{0%{opacity:0;transform:translateY(.5em)rotate(-20deg)}60%{opacity:1;transform:translateY(-.05em)rotate(8deg)}to{opacity:1;transform:translateY(0)rotate(0)}}.milestone-overlay--flourish-canon{background-image:radial-gradient(circle at 50% 30%, color-mix(in srgb, var(--canon-gold) 14%, transparent), transparent 55%)}.milestone-overlay--flourish-canon .milestone-overlay-icon{filter:drop-shadow(0 0 24px color-mix(in srgb, var(--canon-gold) 60%, transparent))}.milestone-overlay--flourish-tree{background-image:radial-gradient(circle at 50% 30%, color-mix(in srgb, var(--sage) 10%, transparent), transparent 55%)}.milestone-overlay-skip-hint{font-size:var(--text-xs);color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;opacity:0;pointer-events:none;animation:3.6s both milestone-overlay-skip;position:absolute;bottom:1.5rem;left:50%;transform:translate(-50%)}@keyframes milestone-overlay-skip{0%,8%{opacity:0}18%,88%{opacity:.55}to{opacity:0}}.milestone-overlay--contained .milestone-overlay-skip-hint{font-size:var(--text-2xs);bottom:.75rem}@media (prefers-reduced-motion:reduce){.milestone-overlay,.milestone-overlay--closing,.milestone-overlay-icon,.milestone-overlay-eyebrow,.milestone-overlay-title,.milestone-overlay-subtitle,.milestone-overlay-flourish-leaf,.milestone-overlay-skip-hint{opacity:1;transform:none;animation:none!important}}.suspended-banner{z-index:100;background:var(--error-bg);border-bottom:1px solid var(--error-border);color:var(--error);font-size:var(--text-base);text-align:center;padding:.75rem 1.25rem;position:relative}.suspended-banner-body{flex-direction:column;gap:.2rem;max-width:1100px;margin:0 auto;line-height:1.4;display:flex}.suspended-banner-reason{color:var(--text-main);font-size:var(--text-sm)}.suspended-banner-hint{color:var(--text-muted);font-size:var(--text-sm);font-style:italic}.age-gate-overlay{background:var(--scrim);z-index:40000;justify-content:center;align-items:center;padding:1.5rem;animation:.18s ease-out age-gate-fade;display:flex;position:fixed;inset:0}@keyframes age-gate-fade{0%{opacity:0}to{opacity:1}}.age-gate-modal{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;max-width:460px;max-height:92dvh;box-shadow:var(--shadow-lg);font-family:var(--font-main);color:var(--text-main);padding:1.85rem 1.85rem 1.6rem;overflow-y:auto}.age-gate-eyebrow{font-size:var(--text-xs);letter-spacing:.18em;text-transform:uppercase;color:var(--terracotta);margin:0 0 .35rem;font-weight:700}.age-gate-title{font-family:var(--font-accent);font-size:var(--text-xl);color:var(--text-main);margin:0 0 .9rem;line-height:1.25}.age-gate-blurb{font-size:var(--text-base);color:var(--text-muted);margin:0 0 1.4rem;line-height:1.55}.age-gate-check{background:var(--bg-surface-alt);border:1.5px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:border-color var(--transition), background var(--transition);align-items:flex-start;gap:.75rem;margin-bottom:1.1rem;padding:.85rem 1rem;display:flex}.age-gate-check:hover{border-color:var(--sage-light)}.age-gate-check:has(input:checked){border-color:var(--terracotta);background:var(--terracotta-tint)}.age-gate-check input[type=checkbox]{accent-color:var(--terracotta);cursor:pointer;flex-shrink:0;width:18px;height:18px;margin-top:.15rem}.age-gate-check span{font-size:var(--text-base);color:var(--text-main);line-height:1.5}.age-gate-check strong{color:var(--terracotta)}.age-gate-fineprint{font-size:var(--text-sm);color:var(--text-muted);margin:0 0 1.5rem;line-height:1.55}.age-gate-fineprint a{color:var(--sage);text-decoration:underline}.age-gate-fineprint a:hover{color:var(--terracotta)}.age-gate-actions{justify-content:flex-end;display:flex}.age-gate-continue{appearance:none;background:var(--terracotta);color:#fff;border-radius:var(--radius-sm);font-family:inherit;font-size:var(--text-base);cursor:pointer;transition:background var(--transition), transform 80ms ease-out;border:none;padding:.7rem 1.6rem;font-weight:700}.age-gate-continue:hover:not(:disabled){background:var(--terracotta-hover)}.age-gate-continue:active:not(:disabled){transform:scale(.98)}.age-gate-continue:disabled{opacity:.5;cursor:not-allowed}@media (width<=600px){.age-gate-modal{max-height:95dvh;padding:1.45rem 1.25rem 1.25rem}.age-gate-title{font-size:var(--text-lg)}}.onb-overlay{background:var(--scrim);z-index:39000;justify-content:center;align-items:center;padding:1.5rem;animation:.2s ease-out onb-fade;display:flex;position:fixed;inset:0}@keyframes onb-fade{0%{opacity:0}to{opacity:1}}.onb-modal{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;max-width:440px;box-shadow:var(--shadow-lg);font-family:var(--font-main);color:var(--text-main);padding:2rem 2rem 1.75rem;animation:.25s cubic-bezier(.22,1,.36,1) both onb-rise}@keyframes onb-rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.onb-eyebrow{font-size:var(--text-xs);letter-spacing:.18em;text-transform:uppercase;color:var(--terracotta);margin:0 0 .35rem;font-weight:700}.onb-title{font-family:var(--font-accent);color:var(--text-main);margin:0 0 .85rem;font-size:clamp(1.6rem,5vw,2rem);line-height:1.2}.onb-blurb{font-size:var(--text-base);color:var(--text-muted);margin:0 0 1.5rem;line-height:1.65}.onb-actions{justify-content:space-between;align-items:center;gap:.75rem;margin-top:.25rem;display:flex}.onb-actions-stack{flex-direction:column;align-items:stretch}.onb-primary{appearance:none;background:var(--terracotta);color:#fff;border-radius:var(--radius-sm);font-family:inherit;font-size:var(--text-base);cursor:pointer;text-align:center;transition:background var(--transition), transform 80ms ease-out;border:none;padding:.75rem 1.6rem;font-weight:700;text-decoration:none;display:inline-block}.onb-primary:hover:not(:disabled){background:var(--terracotta-hover,var(--terracotta));filter:brightness(1.06)}.onb-primary:active:not(:disabled){transform:scale(.98)}.onb-primary:disabled{opacity:.5;cursor:not-allowed}.onb-primary-block{width:100%}.onb-secondary{appearance:none;color:var(--text-muted);border:1.5px solid var(--border-color);border-radius:var(--radius-sm);font-family:inherit;font-size:var(--text-base);cursor:pointer;text-align:center;transition:border-color var(--transition), color var(--transition);background:0 0;padding:.65rem 1.6rem;font-weight:500;text-decoration:none;display:inline-block}.onb-secondary:hover:not(:disabled){border-color:var(--terracotta);color:var(--terracotta)}.onb-secondary:disabled{opacity:.5;cursor:not-allowed}@media (width<=600px){.onb-modal{padding:1.5rem 1.25rem 1.35rem}}.gs-overlay{z-index:10015;background:var(--scrim);justify-content:center;align-items:flex-start;padding-top:12vh;animation:.12s gs-fade-in;display:flex;position:fixed;inset:0}@keyframes gs-fade-in{0%{opacity:0}to{opacity:1}}.gs-modal{background:var(--bg-surface);border-radius:var(--radius-md);width:100%;max-width:580px;box-shadow:var(--shadow-modal);border:1px solid var(--border-color);animation:.15s cubic-bezier(.4,0,.2,1) gs-slide-in;overflow:hidden}@keyframes gs-slide-in{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.gs-input-row{border-bottom:1px solid var(--border-color);align-items:center;gap:.6rem;padding:.9rem 1rem;display:flex}.gs-search-icon{color:var(--terracotta);flex-shrink:0}.gs-input{font-family:var(--font-main);font-size:var(--text-md);color:var(--text-main);background:0 0;border:none;outline:none;flex:1;min-width:0}.gs-input::placeholder{color:var(--text-muted)}.gs-input::-webkit-search-cancel-button{display:none}.gs-clear{cursor:pointer;color:var(--text-muted);border-radius:var(--radius-xs);background:0 0;border:none;flex-shrink:0;align-items:center;padding:.2rem;transition:color .12s,background .12s;display:flex}.gs-clear:hover{color:var(--text-main);background:var(--bg-surface-alt)}.gs-esc{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:var(--text-xs);color:var(--text-muted);background:var(--bg-surface-alt);border:1px solid var(--border-color);border-radius:var(--radius-xs);-webkit-user-select:none;user-select:none;cursor:pointer;flex-shrink:0;padding:.15rem .45rem;transition:color .12s,border-color .12s,background .12s}.gs-esc:hover{color:var(--text-main);border-color:var(--text-muted);background:var(--bg-surface)}.gs-results{max-height:360px;margin:0;padding:.35rem 0;list-style:none;overflow-y:auto}.gs-result{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.75rem;width:100%;padding:.6rem 1rem;font-family:inherit;transition:background 80ms;display:flex}.gs-result:hover,.gs-result.active{background:var(--terracotta-tint);border-left:2px solid var(--terracotta);padding-left:calc(1rem - 2px)}.gs-thumb{border-radius:var(--radius-sm);background:var(--bg-surface-alt);border:1px solid var(--border-color);flex-shrink:0;width:42px;height:42px;overflow:hidden}.gs-thumb img{object-fit:cover;width:100%;height:100%}.gs-thumb-placeholder{background:var(--bg-surface-alt);width:100%;height:100%;display:block}.gs-info{flex-direction:column;flex:1;gap:.15rem;min-width:0;display:flex}.gs-title{font-size:var(--text-base);color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.gs-meta{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.gs-category{font-size:var(--text-xs);color:var(--terracotta);background:var(--terracotta-tint);border:1px solid color-mix(in srgb, var(--terracotta) 25%, transparent);border-radius:var(--radius-xs);white-space:nowrap;flex-shrink:0;padding:.15rem .5rem}.gs-empty,.gs-hint{font-size:var(--text-sm);color:var(--text-muted);text-align:center;margin:0;padding:1.25rem 1rem}.gs-empty strong{color:var(--text-main);font-weight:600}@media (width<=600px){.gs-overlay{align-items:flex-end;padding-top:0}.gs-modal{border-radius:var(--radius-md) var(--radius-md) 0 0;max-width:100%;max-height:calc(92vh - env(safe-area-inset-bottom,0px));flex-direction:column;display:flex}.gs-results{-webkit-overflow-scrolling:touch;flex:1;max-height:none;overflow-y:auto}.gs-esc{display:none}}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--sage-deep:#2d3436;--sage:#52665e;--sage-light:#8ba89e;--cream:#f4f1ea;--cream-light:#faf9f6;--terracotta:#e17055;--terracotta-hover:#cf6348;--terracotta-dark:#b85a3e;--terracotta-text:#a84a30;--accent:#fab1a0;--white:#fff;--dark:#2d3436;--dark-light:#636e72;--gray-light:#dfe6e9;--bg-main:#fdfcf0;--bg-surface:#fff;--bg-surface-alt:#f7f1e3;--text-main:#2d3436;--text-muted:#636e72;--text-inverse:#fff;--border-color:#dfe6e9;--border-color-strong:#b2bec3;--error:#c53030;--error-bg:#fff5f5;--error-border:#feb2b2;--error-hover:#9b2c2c;--error-bg-subtle:#c530301a;--success:#2f855a;--success-bg:#2f855a14;--success-bg-soft:#d4edda;--success-text:#1a7340;--success-border:#a3d4b4;--warning:#b8860b;--warning-bg:#fff8e1;--warning-border:#f0d060;--error-bg-hover:#fee2e2;--canon-gold:#d4a017;--canon-gold-strong:#b78813;--cat-main:#e17055;--cat-side:#9c6f1d;--cat-soup:#5e7ea3;--cat-salad:#6fa46b;--cat-breakfast:#a8761a;--cat-bread:#8a6840;--cat-appetizer:#7d6a8c;--cat-dessert:#a84a6f;--cat-beverage:#4a7c74;--cat-sauce:#2d3436;--cat-unknown:#4b6584;--terracotta-tint:#e170550f;--terracotta-subtle:#e170550d;--terracotta-glow:#e1705526;--sage-tint:#e6f0ea;--sage-alpha-20:#52665e33;--sage-alpha-40:#52665e66;--scrim:#0000008c;--backdrop-surface:#fffffff2;--primary:var(--sage);--primary-deep:var(--sage-deep);--accent-sage:var(--sage-light);--text-secondary:var(--text-muted);--font-main:"Outfit", sans-serif;--font-accent:"Playfair Display", serif;--text-2xs:.65rem;--text-xs:.75rem;--text-sm:.82rem;--text-base:.9rem;--text-md:1rem;--text-lg:1.2rem;--text-xl:1.5rem;--text-2xl:2rem;--text-display:3rem;--leading-tight:1.2;--leading-snug:1.4;--leading-normal:1.5;--leading-relaxed:1.65;--focus-ring:2px solid var(--sage-deep);--navbar-height:72px;--space-2xs:.25rem;--space-xs:.5rem;--space-sm:1rem;--space-md:1.5rem;--space-xl:2rem;--space-lg:3rem;--space-2xl:5rem;--radius-xs:4px;--radius-sm:8px;--radius-md:16px;--radius-lg:32px;--radius-pill:999px;--shadow:0 1px 3px #0000000d, 0 4px 14px #00000012;--shadow-hover:0 2px 6px #00000014, 0 8px 20px #0000001a;--shadow-sm:0 1px 2px #0000000d, 0 2px 6px #0000000a;--shadow-md:0 2px 8px #00000012, 0 1px 3px #0000000a;--shadow-lg:0 4px 16px #0000001a, 0 2px 6px #0000000f;--shadow-timeline:0 -4px 25px #00000026;--shadow-modal:0 8px 32px #0000002e;--elevation-popover:var(--shadow-md);--elevation-modal:var(--shadow-modal);--elevation-toast:var(--shadow-lg);--motion-duration-micro:80ms;--motion-duration-quiet:.18s;--motion-duration-enter:.24s;--motion-duration-milestone:.6s;--motion-ease-standard:cubic-bezier(.4, 0, .2, 1);--motion-ease-arrive:cubic-bezier(.2, .8, .2, 1);--motion-ease-depart:cubic-bezier(.4, 0, 1, 1);--motion-micro:var(--motion-duration-micro) var(--motion-ease-standard);--motion-quiet:var(--motion-duration-quiet) var(--motion-ease-standard);--motion-standard:var(--motion-duration-enter) var(--motion-ease-standard);--motion-enter:var(--motion-duration-enter) var(--motion-ease-arrive);--motion-exit:var(--motion-duration-quiet) var(--motion-ease-depart);--motion-milestone:var(--motion-duration-milestone) var(--motion-ease-arrive);--transition:all var(--motion-standard)}[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg-main:#141814;--bg-surface:#1c221c;--bg-surface-alt:#252d25;--text-main:#e8ece8;--text-muted:#a0a8a0;--text-inverse:#141814;--border-color:#2d362d;--border-color-strong:#3d493d;--shadow:0 8px 32px #0006;--shadow-hover:0 16px 56px #00000080;--sage-light:#5d748d;--cream-light:#1c221c;--gray-light:#2d362d;--error-bg:#c5303026;--error-border:#c530304d;--success:#4ade80;--success-bg:#4ade801f;--success-bg-soft:#2f855a33;--success-text:#4ade80;--success-border:#2f855a66;--warning:#fbbf24;--warning-bg:#fbbf241a;--warning-border:#fbbf244d;--error-bg-hover:#dc262626;--scrim:#0009;--terracotta-tint:#e170551a;--terracotta-glow:#e1705540;--sage-tint:#52665e38;--terracotta-text:#e17055;--terracotta-dark:#e17055;--error-bg-subtle:#c5303026;--shadow-modal:0 8px 32px #0006;--canon-gold:#f0c14b;--canon-gold-strong:#f5d27a;--backdrop-surface:#1c221cf2}@media (prefers-reduced-motion:reduce){:root{--motion-duration-micro:1ms;--motion-duration-quiet:1ms;--motion-duration-enter:1ms;--motion-duration-milestone:1ms}}.btn{border-radius:var(--radius-sm);font-family:var(--font-main);cursor:pointer;white-space:nowrap;min-height:44px;transition:background var(--motion-duration-micro) var(--motion-ease-standard), color var(--motion-duration-micro) var(--motion-ease-standard), border-color var(--motion-duration-micro) var(--motion-ease-standard), box-shadow var(--motion-duration-micro) var(--motion-ease-standard), transform var(--motion-duration-micro) var(--motion-ease-standard), opacity var(--motion-duration-micro) var(--motion-ease-standard);border:none;justify-content:center;align-items:center;gap:.4em;padding:.55rem 1.15rem;font-size:.9375rem;font-weight:700;line-height:1.2;text-decoration:none;display:inline-flex;position:relative}.btn:disabled,.btn[aria-disabled=true]{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-sm{border-radius:calc(var(--radius-sm) - 1px);padding:.38rem .85rem;font-size:.78rem}.btn-lg{font-size:var(--text-md);padding:.75rem 1.6rem}.btn-primary{background:var(--terracotta);color:#fff;border:1.5px solid #0000}.btn-primary:hover:not(:disabled){background:var(--terracotta-dark,#b85a3e);transform:translateY(-1px);box-shadow:0 2px 8px #c45a3c40}.btn-primary:active:not(:disabled){box-shadow:none;transform:translateY(0)}.btn-secondary{color:var(--terracotta);border:1.5px solid var(--terracotta);background:0 0}.btn-secondary:hover:not(:disabled){background:var(--terracotta-tint,#c45a3c12);transform:translateY(-1px);box-shadow:0 2px 6px #c45a3c1f}.btn-secondary:active:not(:disabled){box-shadow:none;transform:translateY(0)}.btn-ghost{color:var(--text-main);border:1.5px solid var(--border-color);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg-surface-alt,var(--bg-surface));border-color:var(--border-color-strong)}.btn-danger{background:var(--error,#c0392b);color:#fff;border:1.5px solid #0000}.btn-danger:hover:not(:disabled){background:var(--error-hover);transform:translateY(-1px);box-shadow:0 2px 8px #c0392b40}.btn-danger:active:not(:disabled){box-shadow:none;transform:translateY(0)}.btn-link{color:var(--terracotta);background:0 0;border:1.5px solid #0000;padding-left:0;padding-right:0;font-weight:600}.btn-link:hover:not(:disabled){color:var(--terracotta-dark,#b85a3e);text-decoration:underline}.btn-icon{border-radius:var(--radius-sm);background:var(--bg-surface);width:2rem;height:2rem;color:var(--text-muted);border:1.5px solid var(--border-color);padding:0}.btn-icon:hover:not(:disabled){background:var(--bg-surface-alt);color:var(--text-main)}.btn-icon.btn-sm{width:1.75rem;height:1.75rem;padding:0}.btn-icon.btn-lg{width:2.5rem;height:2.5rem;padding:0}.btn-pill{border-radius:var(--radius-pill)}.btn-loading{pointer-events:none}.btn-spinner{border:2px solid;border-top-color:#0000;border-radius:50%;flex-shrink:0;width:.85em;height:.85em;animation:.65s linear infinite btn-spin;display:inline-block}@keyframes btn-spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion:reduce){.btn{transition:none}.btn-spinner{opacity:.6;animation:none}*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.sr-only-focusable:focus,.sr-only-focusable:focus-visible{clip:auto;white-space:normal;background:var(--bg-main);width:auto;height:auto;color:var(--text-main);border:2px solid var(--sage-deep);outline:var(--focus-ring);outline-offset:2px;border-radius:4px;margin:0;padding:.5rem 1rem;position:static;overflow:visible}.skip-link{z-index:99999;background:var(--bg-main);color:var(--text-main);border:2px solid var(--sage-deep);border-radius:0 0 6px;padding:.75rem 1.25rem;font-weight:600;text-decoration:none;transition:top .15s ease-out;position:absolute;top:-100px;left:0}.skip-link:focus,.skip-link:focus-visible{outline:var(--focus-ring);outline-offset:2px;top:0}:focus-visible{outline:var(--focus-ring);outline-offset:3px;border-radius:3px}.reaction-btn:focus-visible,.sl-trigger-pill:focus-visible,.era-pill:focus-visible,.memory-reply-affordance button:focus-visible{border-radius:999px}.form-group input:focus-visible,.form-group select:focus-visible,.form-group textarea:focus-visible{outline:none}body{font-family:var(--font-main);background-color:var(--bg-main);color:var(--text-main);-webkit-font-smoothing:antialiased;transition:background-color var(--motion-standard), color var(--motion-standard);line-height:1.5}html,body{overscroll-behavior-y:contain}#root{width:100vw;height:100vh}.app-layout{background-color:var(--bg-main);flex-direction:column;height:100vh;display:flex;position:relative;overflow:hidden}.app-content{flex-direction:column;flex:1;height:0;display:flex;position:relative;overflow:hidden}.loading-overlay{background:var(--bg-surface-alt);z-index:9999;font-family:var(--font-accent);font-size:var(--text-xl);color:var(--text-main);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.route-enter{flex-direction:column;flex:1;min-height:0;display:flex}@media (prefers-reduced-motion:no-preference){.route-enter{animation:.12s ease-out route-fade-in}}@keyframes route-fade-in{0%{opacity:0}to{opacity:1}}.spacer{flex:1}.form-group{margin-bottom:var(--space-md)}.form-group label{margin-bottom:var(--space-xs);color:var(--text-main);font-weight:700;font-size:var(--text-base);display:block}.form-label-optional{color:var(--text-muted);font-style:italic;font-weight:500}.form-field-hint{font-size:var(--text-sm);color:var(--text-muted);line-height:var(--leading-snug);margin:.35rem 0 0}.visibility-seg{border:1px solid var(--border-color);border-radius:var(--radius-sm);margin-bottom:.6rem;display:inline-flex;overflow:hidden}.vis-seg-btn{background:var(--bg-surface);border:none;border-right:1px solid var(--border-color);font-family:var(--font-main);font-size:var(--text-sm);color:var(--text-muted);cursor:pointer;white-space:nowrap;flex:1 0 auto;padding:.45rem 1.1rem;font-weight:500;line-height:1.4;transition:background .1s,color .1s}.vis-seg-btn:last-child{border-right:none}.vis-seg-btn:hover:not(.is-active){background:var(--bg-surface-alt);color:var(--text-main)}.vis-seg-btn.is-active{background:var(--terracotta);color:#fff;font-weight:600}.visibility-seg-desc{font-size:var(--text-sm);color:var(--text-muted);line-height:var(--leading-snug);margin:0 0 .75rem}@media (width<=480px){.visibility-seg{width:100%;display:flex}.vis-seg-btn{font-size:var(--text-xs);text-align:center;flex:1;padding:.45rem .5rem}}.form-label-required{color:var(--error);margin-left:.1rem;font-weight:800}.form-group input,.form-group select{border:1.5px solid var(--border-color);border-radius:var(--radius-sm);width:100%;font-family:var(--font-main);font-size:var(--text-md);background:var(--bg-surface);height:45px;color:var(--text-main);transition:var(--transition);padding:.8rem 1rem}.form-group textarea{border:1.5px solid var(--border-color);border-radius:var(--radius-sm);width:100%;font-family:inherit;font-size:var(--text-md);resize:none;background:var(--bg-surface);min-height:120px;color:var(--text-main);transition:var(--transition);padding:1rem;line-height:1.6}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--terracotta);box-shadow:0 0 0 3px var(--terracotta-glow);outline:none}.form-group input.is-invalid,.form-group textarea.is-invalid,.form-group select.is-invalid{border-color:var(--error);box-shadow:0 0 0 3px color-mix(in srgb, var(--error) 22%, transparent);animation:.42s cubic-bezier(.36,.07,.19,.97) both form-error-shake}@keyframes form-error-shake{0%,to{transform:translate(0)}15%{transform:translate(-6px)}30%{transform:translate(6px)}45%{transform:translate(-4px)}60%{transform:translate(4px)}75%{transform:translate(-2px)}90%{transform:translate(2px)}}.form-error-message{font-size:var(--text-sm);color:var(--error);align-items:flex-start;gap:.35rem;margin:.45rem 0 0;line-height:1.4;display:flex}.form-error-message:before{content:"•";flex-shrink:0;font-weight:800}@media (prefers-reduced-motion:reduce){.form-group input.is-invalid,.form-group textarea.is-invalid,.form-group select.is-invalid{animation:none}}.form-row{gap:var(--space-sm);grid-template-columns:1fr 1fr;display:grid}.visibility-options{gap:var(--space-xs);flex-direction:column;display:flex}.visibility-option{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-surface);cursor:pointer;transition:var(--transition);grid-template-rows:auto auto;grid-template-columns:auto 1fr;align-items:center;column-gap:.75rem;padding:.75rem 1rem;display:grid}.visibility-option:hover{border-color:var(--sage-light)}.visibility-option.active{border-color:var(--terracotta);background:var(--terracotta-tint)}.visibility-option input[type=radio],.visibility-option input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:var(--terracotta);grid-row:span 2}.visibility-title{color:var(--text-main);font-weight:700;font-size:var(--text-base)}.visibility-desc{font-size:var(--text-sm);color:var(--text-muted)}.visibility-hint{margin:var(--space-sm) 0 var(--space-xs) 0;font-size:var(--text-sm);color:var(--text-muted)}.visibility-hint-private{margin-top:var(--space-sm);background:var(--bg-surface);border:1px dashed var(--border-color);border-radius:var(--radius-sm);color:var(--text-main);text-align:center;padding:.6rem .85rem;font-weight:600}.family-picker{margin-top:var(--space-xs);flex-direction:column;gap:.4rem;display:flex}.family-picker-item{align-items:center;gap:var(--space-xs);padding:var(--space-xs) .75rem;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-base);display:flex}.family-picker-item input{width:16px;height:16px}.is-new-arrival{animation:.7s ease-out both new-arrival-card-in;position:relative}@keyframes new-arrival-card-in{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.is-new-arrival:after{content:"🌿";font-size:var(--text-lg);opacity:0;pointer-events:none;filter:drop-shadow(0 1px 2px #0000002e);z-index:3;animation:.85s ease-out .4s forwards new-arrival-leaf-trace;position:absolute;top:.4rem;right:.6rem;transform:translate(-.3em)rotate(-12deg)}@keyframes new-arrival-leaf-trace{0%{opacity:0;transform:translate(-.3em)rotate(-12deg)}30%{opacity:.9;transform:translate(0)rotate(0)}70%{opacity:.7;transform:translate(.4em)rotate(8deg)}to{opacity:0;transform:translate(.9em)rotate(14deg)}}@media (prefers-reduced-motion:reduce){.is-new-arrival{opacity:1;animation:none;transform:none}.is-new-arrival:after{display:none}}.sidebar-scroll::-webkit-scrollbar{width:6px}.detail-scroll-area::-webkit-scrollbar{width:6px}.list-page-container::-webkit-scrollbar{width:6px}.sidebar-scroll::-webkit-scrollbar-track{background:0 0}.detail-scroll-area::-webkit-scrollbar-track{background:0 0}.list-page-container::-webkit-scrollbar-track{background:0 0}.sidebar-scroll::-webkit-scrollbar-thumb{background:var(--sage-alpha-20);border-radius:var(--radius-sm)}.detail-scroll-area::-webkit-scrollbar-thumb{background:var(--sage-alpha-20);border-radius:var(--radius-sm)}.list-page-container::-webkit-scrollbar-thumb{background:var(--sage-alpha-20);border-radius:var(--radius-sm)}.sidebar-scroll::-webkit-scrollbar-thumb:hover{background:var(--sage-alpha-40)}.detail-scroll-area::-webkit-scrollbar-thumb:hover{background:var(--sage-alpha-40)}.list-page-container::-webkit-scrollbar-thumb:hover{background:var(--sage-alpha-40)}.app-nav{background-color:var(--bg-surface);color:var(--text-main);z-index:20000;border-bottom:1px solid var(--border-color);align-items:center;display:flex;position:relative;height:72px!important;min-height:72px!important}.nav-container{align-items:center;width:100%;padding:0 1.5rem;display:flex}.nav-toggle{display:none}.nav-logo{font-size:var(--text-xl);color:var(--text-main);align-items:center;gap:var(--space-xs);letter-spacing:-.02em;margin-right:auto;font-weight:700;text-decoration:none;display:flex}.logo-wordmark{font-family:var(--font-accent);letter-spacing:-.02em;font-weight:700;line-height:1}.logo-food{color:var(--terracotta)}.logo-ymology{color:var(--text-main)}.nav-header-actions{order:3;align-items:center;gap:.5rem;margin-left:1rem;display:flex}.nav-search-btn{border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;background:0 0;justify-content:center;align-items:center;padding:.35rem .5rem;transition:color .12s,border-color .12s,background .12s;display:flex}.nav-search-btn:hover{color:var(--text-main);border-color:var(--border-color-strong);background:var(--bg-surface-alt)}.nav-links{align-items:center;gap:var(--space-md);display:flex}.nav-links a{color:var(--text-muted);transition:var(--transition);font-weight:500;text-decoration:none}.nav-links a:hover,.nav-links a.active{color:var(--text-main)}.nav-links a.active{font-weight:700;position:relative}.nav-links a.active:after{content:"";background-color:var(--terracotta);width:100%;height:2px;position:absolute;bottom:-4px;left:0}.nav-links .nav-link-btn{font:inherit;color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;border:none;align-items:center;gap:.4rem;padding:0;font-weight:500;display:inline-flex}.nav-links .nav-link-btn:hover{color:var(--text-main)}.bottom-tab-bar{display:none}.nav-link-badge{background:var(--terracotta);min-width:18px;height:18px;color:var(--white);font-size:var(--text-xs);border-radius:999px;justify-content:center;align-items:center;padding:0 .4rem;font-weight:800;line-height:1;display:inline-flex}.user-profile{align-items:center;gap:1rem;margin-left:.5rem;display:flex}.user-initial{background:var(--terracotta);color:#fff;width:32px;height:32px;font-weight:700;font-size:var(--text-base);border:2px solid #fff3;border-radius:50%;justify-content:center;align-items:center;display:flex}.nav-contribute-btn{background-color:var(--terracotta);border-radius:var(--radius-sm);transition:var(--transition);font-weight:700;font-size:var(--text-sm);padding:.4rem 1.25rem;color:var(--white)!important}.nav-contribute-btn:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.nav-logout-btn{color:#fff;border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-main);transition:var(--transition);background:0 0;border:1px solid #ffffff4d;padding:.4rem 1rem;font-weight:500}.map-page-container{background-color:var(--bg-main);flex:1;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.map-view{z-index:1;height:100%;transition:flex var(--motion-duration-enter) var(--motion-ease-standard);flex:1;position:relative}.map-sidebar{width:var(--sidebar-width);background:var(--bg-surface);z-index:10002;height:100%;box-shadow:var(--elevation-modal);flex-direction:column;animation:.4s cubic-bezier(.4,0,.2,1) slideInLeft;display:flex}.sidebar-scroll{flex-direction:column;flex:1;gap:1rem;min-height:0;padding:1rem;display:flex;overflow-y:auto}@keyframes slideInLeft{0%{opacity:0;transform:translate(-100%)}to{opacity:1;transform:translate(0)}}.sidebar-header{background:var(--bg-surface-alt);border-bottom:1px solid var(--border-color);align-items:center;min-height:50px;padding:.75rem 1.5rem;display:flex}.sidebar-count{font-size:var(--text-xs);text-transform:uppercase;color:var(--terracotta);letter-spacing:.1em;margin-bottom:.25rem;font-weight:800;display:block}.sidebar-header h2{font-family:var(--font-accent);color:var(--text-main);font-size:1.8rem}.sidebar-card{background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border-color);cursor:pointer;transition:var(--transition);gap:1rem;padding:1rem;display:flex}.sidebar-card:hover{box-shadow:var(--shadow-md);border-color:var(--text-muted);transform:translateY(-4px)}.sidebar-card.active{border-color:var(--terracotta);background:var(--terracotta-subtle)}.sidebar-card.is-canon{border-color:var(--canon-gold);box-shadow:inset 3px 0 0 var(--canon-gold)}.sidebar-card.is-canon.active{border-color:var(--terracotta);box-shadow:inset 3px 0 0 var(--canon-gold)}.card-canon-badge{vertical-align:-1px;filter:drop-shadow(0 1px 1px #00000026);margin-left:.4rem;font-size:.95em;line-height:1;display:inline-block}.card-thumb{border-radius:var(--radius-sm);background:var(--gray-light);flex-shrink:0;width:80px;height:80px;overflow:hidden}.card-thumb img{object-fit:cover;width:100%;height:100%}.thumb-placeholder{width:100%;height:100%;font-size:var(--text-xl);background:var(--bg-surface-alt);justify-content:center;align-items:center;display:flex}.thumb-placeholder-emoji{filter:drop-shadow(0 1px 1px #00000014);font-size:2.4rem;line-height:1}.sidebar-card-info{flex-direction:column;flex:1;justify-content:center;gap:.25rem;display:flex}.card-cat{font-size:var(--text-xs);text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;font-weight:700}.sidebar-card-info h3{font-size:var(--text-lg);color:var(--text-main);margin:0}.card-loc{font-size:var(--text-sm);color:var(--text-muted)}.sidebar-empty{text-align:center;color:var(--text-muted);padding:4rem 2rem}.empty-icon{font-size:var(--text-display);opacity:.3;margin-bottom:1rem;display:block}.sidebar-controls{background:var(--bg-surface);border-bottom:1px solid var(--border-color)}.sidebar-control-main{align-items:center;gap:.75rem;padding:0 1.5rem 1.25rem;display:flex}.sidebar-collection-top{padding:1.25rem 1.5rem .5rem}.sidebar-collection-top .collection-switcher{background:var(--bg-surface-alt);border:1.5px solid var(--border-color);border-radius:var(--radius-sm);width:100%;box-shadow:none;justify-content:space-between;gap:.25rem;padding:.25rem;display:flex}.sidebar-collection-top .collection-item{text-align:center;font-size:var(--text-xs);border-radius:var(--radius-xs);color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:.4rem;padding:.5rem .25rem;font-weight:600;display:flex}.sidebar-collection-top .collection-item.active{background:var(--bg-surface);color:var(--terracotta);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.sidebar-collection-top .col-icon{font-size:var(--text-base)}.sidebar-search{flex:1;position:relative}.sidebar-search .search-icon{opacity:.5;position:absolute;top:50%;left:.75rem;transform:translateY(-50%)}.sidebar-search input{border:1.5px solid var(--border-color);border-radius:var(--radius-sm);width:100%;font-family:var(--font-main);font-size:var(--text-base);transition:var(--transition);background:var(--bg-surface-alt);color:var(--text-main);padding:.65rem 1rem .65rem 2.25rem}.sidebar-search input:focus{border-color:var(--text-muted);background:var(--bg-surface);outline:none;box-shadow:0 0 0 4px #8ba89e1a}.filter-toggle-btn{background:var(--bg-surface);border:1.5px solid var(--border-color);border-radius:var(--radius-sm);font-weight:700;font-size:var(--text-sm);color:var(--text-main);cursor:pointer;transition:var(--transition);align-items:center;gap:.5rem;padding:.6rem 1rem;display:flex}.filter-toggle-btn:hover{background:var(--gray-light);border-color:var(--text-muted)}.filter-toggle-btn.active{background:var(--sage);color:var(--white);border-color:var(--text-main)}.expanded-filters-area{background:var(--bg-surface);padding:0 1.5rem 1.5rem;animation:.3s ease-out slideDownFade}@keyframes slideDownFade{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.sidebar-filters{background:var(--bg-surface-alt);border-radius:var(--radius-md);border:1px solid var(--border-color);flex-direction:column;gap:.75rem;padding:1.25rem;display:flex}.filter-group{flex-direction:column;gap:.5rem;display:flex}.filter-group label{font-size:var(--text-xs);text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;justify-content:space-between;align-items:center;gap:.5rem;font-weight:800;display:flex}.filter-clear-btn{appearance:none;color:var(--terracotta);font-family:inherit;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;background:0 0;border:none;padding:.1rem .3rem;font-weight:700}.filter-clear-btn:hover{text-decoration:underline}.era-chip-group{flex-wrap:wrap;gap:.35rem;display:flex}.era-chip{appearance:none;border:1.5px solid var(--border-color);background:var(--bg-surface);color:var(--text-main);font-family:inherit;font-size:var(--text-sm);cursor:pointer;transition:background var(--transition), border-color var(--transition), color var(--transition);border-radius:999px;align-items:center;gap:.3rem;padding:.35rem .6rem;font-weight:600;line-height:1.1;display:inline-flex}.era-chip:hover{border-color:var(--sage-light)}.era-chip.active{background:var(--terracotta);border-color:var(--terracotta);color:var(--white)}.era-chip-icon{font-size:var(--text-base);line-height:1}.era-chip-label{white-space:nowrap}.era-untagged-toggle{font-size:var(--text-sm);color:var(--text-muted);cursor:pointer;text-transform:none;letter-spacing:0;align-items:center;gap:.5rem;margin-top:.6rem;font-weight:500;display:flex}.era-untagged-toggle input[type=checkbox]{width:14px;height:14px;accent-color:var(--terracotta);cursor:pointer}.detail-era-row{flex-direction:column;gap:.45rem;margin-top:1rem;display:flex}.detail-era-badges{flex-wrap:wrap;gap:.35rem;display:flex}.detail-era-badge{background:var(--sage-alpha-20);border:1px solid var(--sage-light);border-radius:var(--radius-pill);font-size:var(--text-sm);letter-spacing:.02em;color:var(--text-main);font-variant-numeric:tabular-nums;align-items:center;padding:.3rem .7rem;font-weight:600;display:inline-flex}.detail-era-untagged{appearance:none;border:1px dashed var(--border-color);color:var(--text-muted);font-family:inherit;font-size:var(--text-sm);cursor:pointer;transition:border-color var(--transition), color var(--transition);background:0 0;border-radius:999px;align-self:flex-start;align-items:center;gap:.4rem;padding:.4rem .7rem;font-style:italic;display:inline-flex}.detail-era-untagged:hover{border-color:var(--terracotta);color:var(--terracotta)}.detail-era-untagged-cta{color:var(--terracotta);font-style:normal;font-weight:700}.filter-group select{border:1.5px solid var(--border-color);border-radius:var(--radius-sm);width:100%;font-family:var(--font-main);background:var(--bg-surface);color:var(--text-main);cursor:pointer;font-size:var(--text-base);padding:.6rem .75rem}.sidebar-collection-wrapper .collection-switcher{box-shadow:none;background:0 0;border:none;flex-wrap:wrap;gap:.4rem;padding:0}.sidebar-collection-wrapper .collection-item{font-size:var(--text-sm);background:var(--bg-surface);border:1px solid var(--border-color);padding:.4rem .8rem}.sidebar-collection-wrapper .collection-item.active{background:var(--sage);border-color:var(--text-main)}.category-bar{background:var(--bg-surface);border-bottom:1px solid var(--border-color);padding:1.25rem 1.5rem;overflow:hidden}.category-scroll-container{scrollbar-width:none;gap:.75rem;padding-bottom:.25rem;display:flex;overflow-x:auto}.category-item{background:var(--bg-surface-alt);border:1px solid var(--border-color);border-radius:var(--radius-lg);font-family:var(--font-main);font-weight:700;font-size:var(--text-sm);color:var(--text-muted);cursor:pointer;transition:var(--transition);white-space:nowrap;align-items:center;gap:.6rem;padding:.6rem 1.25rem;display:flex}.category-item:hover{background:var(--bg-surface);border-color:var(--text-muted);color:var(--text-main)}.category-item.active{background:var(--sage);border-color:var(--text-main);color:var(--white);box-shadow:var(--shadow-sm)}.detail-panel{background:var(--bg-surface);z-index:10001;width:0;height:100%;box-shadow:var(--shadow);transition:width var(--motion-duration-enter) var(--motion-ease-standard);border-left:0px solid var(--gray-light);flex-direction:column;display:flex;position:relative;overflow:hidden}.detail-scroll-area{scrollbar-gutter:stable;flex-direction:column;flex:1;min-height:0;display:flex;overflow-y:auto}.detail-body{flex-direction:column;flex:none;display:flex}.detail-hero-container{border-bottom:1px solid var(--border-color);flex:none;position:relative}.detail-chrome{z-index:3;gap:.35rem;display:flex;position:absolute;top:.65rem;right:.65rem}.detail-panel-controls{z-index:3;gap:.35rem;display:flex;position:absolute;top:.65rem;left:.65rem}.detail-chrome-btn{appearance:none;color:#2d3436;cursor:pointer;background:#fff;border:1px solid #0000001f;border-radius:50%;justify-content:center;align-items:center;width:2.25rem;height:2.25rem;transition:background .12s,color .12s,transform .12s;display:inline-flex;box-shadow:0 2px 6px #00000040}.detail-chrome-btn:hover{background:var(--terracotta);color:#fff;transform:translateY(-1px)}.detail-chrome-btn--close{color:#fff;background:#0000008c;border-color:#ffffff40}.detail-chrome-btn--close:hover{background:var(--error,#c53030);color:#fff}.detail-chrome-more-wrap{position:relative}.detail-chrome-more-menu{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-sm);min-width:12rem;box-shadow:var(--shadow-md,0 8px 24px #0000002e);z-index:4;flex-direction:column;gap:.1rem;padding:.3rem;display:flex;position:absolute;top:calc(100% + .4rem);right:0}.detail-chrome-more-item{appearance:none;text-align:left;font-family:inherit;font-size:var(--text-sm);color:var(--text-main);border-radius:var(--radius-xs,4px);cursor:pointer;background:0 0;border:none;align-items:center;gap:.55rem;width:100%;padding:.5rem .7rem;transition:background .12s,color .12s;display:inline-flex}.detail-chrome-more-item:hover:not(:disabled){background:var(--bg-surface-alt);color:var(--terracotta)}.detail-chrome-more-item:disabled{opacity:.45;cursor:not-allowed}.detail-chrome-more-item--report{font-size:var(--text-sm)!important;border-radius:var(--radius-xs,4px)!important;background:0 0!important;border:none!important;justify-content:flex-start!important;padding:.5rem .7rem!important;font-weight:500!important}.detail-chrome-more-item--report:hover{background:var(--bg-surface-alt)!important;color:var(--terracotta)!important}.detail-hero-illustration-credit{font-size:var(--text-2xs);letter-spacing:.01em;color:var(--terracotta);background:var(--terracotta-tint);border-top:1px solid color-mix(in srgb, var(--terracotta) 20%, transparent);align-items:center;gap:.35rem;padding:.3rem .85rem;font-style:italic;line-height:1.4;display:flex}.detail-hero-illustration-credit cite{font-style:normal;font-weight:600}.detail-hero-container--placeholder{background:var(--bg-surface-alt)}.detail-hero-placeholder{aspect-ratio:16/9;background:radial-gradient(ellipse at center, var(--bg-surface) 0%, var(--bg-surface-alt) 75%);justify-content:center;align-items:center;width:100%;display:flex}.detail-hero-placeholder-emoji{opacity:.55;filter:saturate(.85);font-size:clamp(3.5rem,11vw,6.5rem);line-height:1}.detail-panel .detail-scroll-area .detail-header{z-index:3;background:var(--bg-surface-alt);position:sticky;top:0}.detail-panel.open{width:var(--detail-width);border-left:1px solid var(--gray-light)}.detail-panel.expanded{width:850px}.detail-panel.story-hidden{transition:width var(--motion-duration-quiet) var(--motion-ease-standard);border-left:none!important;width:0!important}@media (width<=1024px){.detail-panel.story-hidden{border-left:initial!important;pointer-events:none!important;width:100%!important;transition:transform .35s cubic-bezier(.4,0,.2,1)!important;transform:translateY(110%)!important}}.recipe-detail-overlay{background:var(--scrim);z-index:20000;justify-content:center;align-items:center;padding:1rem;animation:.18s ease-out fadeIn;display:flex;position:fixed;inset:0}.recipe-detail-overlay-inner{width:100%;max-width:1200px;height:90vh;max-height:90vh;display:flex}.detail-panel.modal-mode{border-radius:var(--radius-lg);width:100%;height:100%;box-shadow:var(--elevation-modal);transition:none}.detail-panel.page-mode{width:100%;height:100%;box-shadow:none;border:none;border-radius:0;flex:1;transition:none}@media (width>=920px){.detail-panel.page-mode .content-area--two-col{grid-template-columns:minmax(0,38fr) minmax(0,62fr);align-items:start;gap:1.5rem;display:grid}}.detail-summary-sidebar{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-main);flex-direction:column;gap:.85rem;padding:1.1rem 1.2rem;display:flex}@media (width>=920px){.detail-panel.page-mode .content-area--two-col .detail-summary-sidebar{max-height:calc(100vh - 8rem);position:sticky;top:1rem;overflow-y:auto}}@media (width<=919px){.detail-panel.page-mode .detail-summary-sidebar{margin-bottom:1rem}}.detail-summary-block{flex-direction:column;gap:.2rem;display:flex}.detail-summary-block--inline{grid-template-columns:4.5rem 1fr;align-items:baseline;gap:.5rem;display:grid}.detail-summary-label{font-size:var(--text-2xs);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);opacity:.7;font-weight:700}.detail-summary-value{font-family:var(--font-accent);font-size:var(--text-base);color:var(--text-main);font-weight:600}.detail-summary-value--link{appearance:none;text-align:left;cursor:pointer;color:var(--terracotta-text,var(--terracotta));background:0 0;border:none;padding:0;transition:color .12s}.detail-summary-value--link:hover{color:var(--terracotta);text-underline-offset:3px;text-decoration:underline}.detail-summary-eras{flex-wrap:wrap;gap:.3rem;display:flex}.detail-summary-era{background:var(--bg-surface-alt);border:1px solid var(--border-color);border-radius:var(--radius-pill,999px);font-family:var(--font-main);font-size:var(--text-xs);color:var(--text-main);padding:.15rem .5rem;font-weight:600;display:inline-block}.detail-summary-divider{background:var(--border-color);height:1px;margin:.3rem 0}@media (width>=920px){.detail-panel.page-mode .content-area--two-col .origin-section .origin-grid,.detail-panel.page-mode .content-area--two-col .origin-section .detail-era-row{display:none}.detail-panel.page-mode .content-area--two-col .origin-section:has(.ancestry-track:only-child){background:0 0;border:none;padding:0}.detail-panel.page-mode .content-area--two-col .origin-section .ancestry-track{border-top:none;padding-top:0}}.page-gallery-thumb{border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-surface-alt);aspect-ratio:1;min-width:0;min-height:0;overflow:hidden}.page-gallery-thumb img{object-fit:cover;width:100%;height:100%;display:block}.page-gallery-thumb--more{background:var(--bg-surface-alt);font-weight:700;font-size:var(--text-md);color:var(--text-muted);justify-content:center;align-items:center;display:flex}@media (width>=900px){.detail-panel.modal-mode .detail-scroll-area:has(.detail-hero-container){grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);align-items:stretch;column-gap:2.5rem;padding:1.5rem 2rem 0;display:grid}.detail-panel.modal-mode .detail-scroll-area:has(.detail-hero-container)>*{grid-column:1/-1;min-width:0}.detail-panel.modal-mode .detail-scroll-area:has(.detail-hero-container)>.detail-hero-container{border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border-bottom:none;grid-column:1;overflow:hidden}.detail-panel.modal-mode .recipe-hero,.detail-panel.modal-mode .detail-hero-placeholder{aspect-ratio:auto;height:100%;min-height:320px}.detail-panel.modal-mode .detail-scroll-area:has(.detail-hero-container) .detail-header{background:0 0;border-bottom:none;grid-column:2;padding:0;position:static}.detail-panel.modal-mode .detail-scroll-area:has(.detail-hero-container)>.detail-tabs{padding:0}.detail-panel.modal-mode .detail-scroll-area:has(.detail-hero-container)>.detail-body{padding-left:0;padding-right:0}.detail-panel.page-mode .detail-scroll-area{padding:1.5rem var(--space-xl,2rem) 3rem;flex-direction:column;align-items:stretch;gap:1.5rem;display:flex}.detail-panel.page-mode .detail-fw-media{gap:1rem;height:clamp(320px,36vw,520px);display:flex}.detail-panel.page-mode .detail-fw-media>.detail-hero-container{border-radius:var(--radius-md);height:100%;box-shadow:var(--shadow-sm);border:none;flex:1.5;overflow:hidden}.detail-panel.page-mode .detail-fw-media .recipe-hero-gallery{background:0 0;height:100%}.detail-panel.page-mode .detail-fw-media .recipe-hero-thumb-strip{display:none}.detail-panel.page-mode .recipe-hero,.detail-panel.page-mode .detail-hero-placeholder{aspect-ratio:auto;width:100%;height:100%;min-height:0}.detail-panel.page-mode .recipe-hero img{object-fit:cover;width:100%;height:100%}.detail-panel.page-mode .detail-fw-media>.page-gallery-thumbs{flex:1;gap:.6rem;height:100%;min-height:0;display:grid}.detail-panel.page-mode .page-gallery-thumbs--c1{grid-template-rows:1fr;grid-template-columns:1fr}.detail-panel.page-mode .page-gallery-thumbs--c2{grid-template-rows:1fr 1fr;grid-template-columns:1fr}.detail-panel.page-mode .page-gallery-thumbs--c3{grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr}.detail-panel.page-mode .page-gallery-thumbs--c3>.page-gallery-thumb:nth-child(3){grid-column:1/-1}.detail-panel.page-mode .page-gallery-thumbs--c4{grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr}.detail-panel.page-mode .page-gallery-thumb{aspect-ratio:auto;border-radius:var(--radius-sm);min-width:0;min-height:0;box-shadow:var(--shadow-sm);overflow:hidden}.detail-panel.page-mode .page-gallery-thumb img{object-fit:cover;width:100%;height:100%;display:block}.detail-panel.page-mode .page-gallery-thumb--more{background:var(--bg-surface-alt);font-weight:700;font-size:var(--text-md);color:var(--text-muted);justify-content:center;align-items:center;display:flex}.detail-panel.page-mode .detail-scroll-area>.detail-header{background:0 0;border-bottom:none;padding:0;z-index:auto!important;position:static!important;top:auto!important}.detail-panel.page-mode .detail-meta-yield{display:none}.detail-panel.page-mode .detail-meta{gap:.4rem;margin-top:.6rem}.detail-panel.page-mode .detail-meta .detail-meta-item{flex-flow:wrap;align-items:baseline;gap:.4rem}.detail-panel.page-mode .detail-meta .detail-meta-source{margin:0;display:inline}.detail-panel.page-mode .detail-meta .detail-meta-source:before{content:"·";color:var(--text-muted);margin:0 .35rem}.detail-panel.page-mode .detail-scroll-area>.detail-tabs,.detail-panel.page-mode .detail-scroll-area>.detail-body{padding:0}.detail-panel:is(.page-mode,.modal-mode).header-collapsed .detail-scroll-area:has(.detail-hero-container) .detail-header{padding:0;position:static}.detail-panel:is(.page-mode,.modal-mode).header-collapsed .detail-scroll-area:has(.detail-hero-container) :is(.recipe-tag,.recipe-original-name,.recipe-subtitle,.detail-meta,.reactions-row,.recipe-reactions){opacity:1;pointer-events:auto;max-height:none;overflow:visible;margin:revert!important}.detail-panel:is(.page-mode,.modal-mode).header-collapsed .detail-scroll-area:has(.detail-hero-container) .detail-title-group h2{font-size:var(--text-2xl);white-space:normal;padding-right:0}}@media (width<=899px){.detail-panel.page-mode .detail-scroll-area{padding:1rem var(--space-md,1.5rem) 0;flex-direction:column;gap:1.25rem;display:flex}.detail-panel.page-mode .detail-fw-media{flex-direction:column;gap:.75rem;display:flex}.detail-panel.page-mode .detail-fw-media>.detail-hero-container:not(.detail-hero-container--placeholder){border-radius:var(--radius-md);height:auto;overflow:visible}.detail-panel.page-mode .detail-fw-media .recipe-hero{aspect-ratio:auto;border-radius:var(--radius-md);height:240px}.detail-panel.page-mode .detail-fw-media>.detail-hero-container.detail-hero-container--placeholder{border-radius:var(--radius-md);height:160px;overflow:hidden}.detail-panel.page-mode .detail-fw-media>.page-gallery-thumbs{display:none}.detail-panel.page-mode .page-gallery-thumb{aspect-ratio:4/3;border-radius:var(--radius-sm);overflow:hidden}.detail-panel.page-mode .detail-header,.detail-panel.page-mode .detail-scroll-area>.detail-tabs,.detail-panel.page-mode .detail-scroll-area>.detail-body{padding-left:0;padding-right:0}.detail-panel.page-mode .detail-scroll-area>.detail-body{padding-top:.5rem}}.detail-panel .detail-header{transition:padding .22s}.detail-panel .detail-title-group,.detail-panel .detail-title-group h2,.detail-panel .recipe-tag,.detail-panel .recipe-original-name,.detail-panel .recipe-subtitle,.detail-panel .detail-meta,.detail-panel .reactions-row,.detail-panel .recipe-reactions{transition:opacity .18s,max-height .22s,margin .22s,font-size .22s}.detail-panel.header-collapsed .detail-header{flex-direction:row;align-items:center;gap:.5rem;padding-top:.55rem;padding-bottom:.55rem;display:flex;position:sticky;top:0}.detail-panel.header-collapsed .recipe-tag,.detail-panel.header-collapsed .recipe-original-name,.detail-panel.header-collapsed .recipe-subtitle,.detail-panel.header-collapsed .detail-meta,.detail-panel.header-collapsed .reactions-row,.detail-panel.header-collapsed .recipe-reactions{opacity:0;pointer-events:none;max-height:0;overflow:hidden;margin:0!important}.detail-panel.header-collapsed .detail-title-group{flex:1;order:1;min-width:0}.detail-panel.header-collapsed .detail-title-group h2{font-size:var(--text-lg);white-space:nowrap;text-overflow:ellipsis;margin:0;padding-right:0;line-height:1.3;overflow:hidden}.detail-header{background:var(--bg-surface-alt);border-bottom:1px solid var(--border-color);padding:1.5rem 2rem}.header-actions{justify-content:flex-end;gap:1rem;margin-bottom:1rem;display:flex}.history-section{padding:1.5rem 0}.history-section+.history-section{border-top:1px solid var(--border-color)}.history-section h3{font-family:var(--font-accent);font-size:var(--text-lg);color:var(--text-main);border-bottom:1px dotted var(--border-color);letter-spacing:-.005em;flex-wrap:wrap;align-items:baseline;gap:.6rem;margin:0 0 .85rem;padding-bottom:.4rem;font-weight:700;display:flex}.ai-confidence-badge{font-family:var(--font-main);font-size:var(--text-xs);letter-spacing:.06em;text-transform:uppercase;border-radius:var(--radius-pill);white-space:nowrap;border:1px solid;padding:.2rem .55rem;font-weight:700;line-height:1.4}.ai-confidence-high{color:var(--olive,#4a7c3c);border-color:var(--olive,#4a7c3c);background:color-mix(in srgb, var(--olive,#4a7c3c) 10%, transparent)}.ai-confidence-medium{color:#a4720e;background:#a4720e1a;border-color:#a4720e}.ai-confidence-low{color:var(--error,#c53030);border-color:var(--error,#c53030);background:color-mix(in srgb, var(--error,#c53030) 10%, transparent)}.ai-enhanced-badge{font-family:var(--font-main);font-size:var(--text-xs);letter-spacing:.06em;text-transform:uppercase;border-radius:var(--radius-pill);border:1px solid var(--sage-light);color:var(--sage);background:var(--sage-alpha-20);white-space:nowrap;box-shadow:var(--shadow-sm);align-items:center;gap:.3rem;padding:.25rem .65rem;font-weight:700;line-height:1.4;display:inline-flex}.ai-reasoning-disclosure{margin:-.25rem 0 1rem}.ai-reasoning-toggle{appearance:none;color:var(--text-muted);font-family:inherit;font-size:var(--text-sm);cursor:pointer;transition:var(--transition);background:0 0;border:none;align-items:center;gap:.4rem;padding:.2rem 0;font-weight:600;display:inline-flex}.ai-reasoning-toggle:hover{color:var(--text-main)}.ai-reasoning-chevron{color:var(--sage);font-size:.95em;font-weight:800;line-height:1;display:inline-block}.ai-reasoning-body{background:var(--bg-surface-alt);border-left:3px solid var(--terracotta);border-radius:var(--radius-sm);font-style:italic;font-size:var(--text-base);color:var(--text-main);margin:.6rem 0 0;padding:.85rem 1rem;line-height:1.55}.ai-feedback-block{border-top:1px dashed var(--border-color);margin-top:1rem;padding-top:1rem}.ai-feedback-toggle{appearance:none;color:var(--text-muted);font-family:inherit;font-size:var(--text-sm);cursor:pointer;text-underline-offset:3px;transition:var(--transition);background:0 0;border:none;padding:.25rem 0;font-weight:600;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.ai-feedback-toggle:hover{color:var(--terracotta);text-decoration-style:solid}.ai-feedback-form{flex-direction:column;gap:.6rem;display:flex}.ai-feedback-label{font-size:var(--text-sm);color:var(--text-muted);font-weight:700}.ai-feedback-textarea{font:inherit;font-size:var(--text-base);border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--text-main);resize:vertical;box-sizing:border-box;width:100%;min-height:80px;padding:.65rem .75rem}.ai-feedback-textarea:focus{outline:2px solid var(--sage-deep);outline-offset:-1px}.ai-feedback-textarea:disabled{opacity:.6;cursor:not-allowed}.ai-feedback-actions{flex-wrap:wrap;justify-content:flex-end;gap:.5rem;display:flex}.ai-feedback-cancel,.ai-feedback-submit,.ai-feedback-rerun{appearance:none;font:inherit;font-size:var(--text-sm);border-radius:var(--radius-pill);cursor:pointer;transition:var(--transition);border:1px solid var(--border-color);padding:.45rem .95rem;font-weight:700}.ai-feedback-cancel{color:var(--text-muted);background:0 0}.ai-feedback-cancel:hover:not(:disabled){color:var(--text-main);border-color:var(--text-muted)}.ai-feedback-submit{color:var(--terracotta);border-color:var(--terracotta);background:0 0}.ai-feedback-submit:hover:not(:disabled){background:var(--terracotta);color:var(--white,#fff)}.ai-feedback-rerun{background:var(--terracotta);color:var(--white,#fff);border-color:var(--terracotta)}.ai-feedback-rerun:hover:not(:disabled){background:var(--terracotta-hover,#cf6348)}.ai-feedback-cancel:disabled,.ai-feedback-submit:disabled,.ai-feedback-rerun:disabled{opacity:.55;cursor:not-allowed}.enrich-nudge-block{background:var(--bg-surface-alt);border:1px dashed color-mix(in srgb, var(--terracotta) 50%, transparent);border-radius:var(--radius-md);flex-direction:column;gap:.6rem;margin-top:1.25rem;padding:1rem 1.1rem;display:flex}.enrich-nudge-blurb{font-size:var(--text-sm);color:var(--text-muted);align-items:center;gap:.35rem;margin:0;line-height:1.5;display:flex}.enrich-nudge-blurb svg{color:var(--terracotta);flex-shrink:0}.enrich-nudge-error{font-size:var(--text-sm);color:var(--error,#c0392b);margin:0;line-height:1.45}.enrich-nudge-busy{color:var(--text-muted);font-size:var(--text-sm);align-items:center;gap:.6rem;margin-top:1.25rem;font-style:italic;display:flex}.enrich-nudge-busy p{margin:0}@keyframes enrich-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.enrich-nudge-spin{color:var(--terracotta);flex-shrink:0;animation:1.4s linear infinite enrich-spin}.deeper-research-block{background:var(--bg-surface-alt);border:1px dashed var(--terracotta);border-radius:var(--radius-md);margin-top:1.25rem;padding:1rem 1.1rem}.deeper-research-hint{font-size:var(--text-sm);color:var(--text-muted);margin:.6rem 0 0;font-style:italic;line-height:1.55}.detail-start-banner{appearance:none;background:var(--terracotta);color:#fff;border-radius:var(--radius-sm);width:calc(100% - 2.2rem);font-family:inherit;font-size:var(--text-md);text-align:left;cursor:pointer;box-shadow:var(--shadow-sm);border:none;margin:.75rem 1.1rem 0;padding:.85rem 1.1rem;font-weight:700;transition:background .12s,transform .12s;display:block}.detail-start-banner:hover{background:var(--terracotta-hover,color-mix(in srgb, var(--terracotta) 88%, #000));transform:translateY(-1px)}.detail-panel.page-mode .detail-start-banner{width:100%;margin:.75rem 0 0}@media (prefers-reduced-motion:reduce){.detail-start-banner{transition:none}}.detail-panel:not(.modal-mode):not(.page-mode) .recipe-hero-thumb-strip{display:none}.start-story-btn{background:var(--terracotta);border:1.5px solid var(--terracotta);border-radius:var(--radius-md);font-size:var(--text-base);color:#fff;cursor:pointer;transition:var(--transition);letter-spacing:.01em;box-shadow:var(--shadow-sm);justify-content:center;align-items:center;gap:.5rem;padding:.7rem 1.5rem;font-weight:700;display:inline-flex}.start-story-btn:hover{filter:brightness(1.08);box-shadow:var(--shadow-md);transform:translateY(-1px)}.deeper-research-hint strong{color:var(--sage);font-style:normal;font-weight:700}.map-welcome-banner{z-index:500;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);width:min(90vw,480px);box-shadow:var(--shadow-lg);pointer-events:auto;flex-direction:column;gap:.65rem;padding:1.25rem 1.5rem 1.35rem;animation:.3s cubic-bezier(.22,1,.36,1) both map-welcome-rise;display:flex;position:absolute;bottom:5.5rem;left:50%;transform:translate(-50%)}@keyframes map-welcome-rise{0%{opacity:0;transform:translate(-50%)translateY(14px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@media (prefers-reduced-motion:reduce){.map-welcome-banner{animation:none}}.map-welcome-close{color:var(--text-muted);cursor:pointer;transition:color var(--transition);background:0 0;border:none;border-radius:3px;padding:.2rem .3rem;font-size:1.25rem;line-height:1;position:absolute;top:.55rem;right:.75rem}.map-welcome-close:hover{color:var(--text-main)}.map-welcome-eyebrow{font-size:var(--text-2xs);letter-spacing:.12em;text-transform:uppercase;color:var(--terracotta);margin:0;padding-right:1.5rem;font-weight:800}.map-welcome-tagline{font-family:var(--font-accent);color:var(--text-main);margin:0;font-size:clamp(1rem,3vw,1.15rem);line-height:1.4}.map-welcome-options{flex-direction:column;gap:.5rem;margin-top:.35rem;display:flex}.map-welcome-option{background:var(--bg-surface-alt);border:1.5px solid var(--border-color);border-radius:var(--radius-sm);text-align:left;cursor:pointer;width:100%;transition:border-color var(--transition), background var(--transition);align-items:center;gap:.75rem;padding:.75rem .9rem;font-family:inherit;display:flex}.map-welcome-option:hover{border-color:var(--terracotta);background:var(--terracotta-tint)}.map-welcome-option-icon{flex-shrink:0;font-size:1.35rem;line-height:1}.map-welcome-option-body{flex-direction:column;flex:1;gap:.2rem;min-width:0;display:flex}.map-welcome-option-label{font-size:var(--text-sm);color:var(--text-main);font-weight:700;line-height:1.3}.map-welcome-option-desc{font-size:var(--text-xs);color:var(--text-muted);line-height:1.4}.map-welcome-option-arrow{font-size:var(--text-base);color:var(--text-muted);transition:color var(--transition), transform var(--transition);flex-shrink:0}.map-welcome-option:hover .map-welcome-option-arrow{color:var(--terracotta);transform:translate(2px)}@media (width<=1024px){.map-welcome-banner{bottom:calc(56px + env(safe-area-inset-bottom,0px) + .5rem);z-index:10005;width:auto;animation-name:map-welcome-rise-mobile;position:fixed;left:1rem;right:1rem;transform:none}}@keyframes map-welcome-rise-mobile{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@media (width>=1025px){.map-welcome-banner{bottom:2.5rem;left:calc(50% + 140px)}}.lab-map-mock{border-radius:var(--radius-md);border:1px solid var(--border-color);background:linear-gradient(160deg,#3b4754 0%,#303b40 100%);height:320px;position:relative;overflow:hidden}.lab-map-mock-grid{position:absolute;inset:0}.lab-map-mock-dot{background:var(--terracotta);opacity:.55;border-radius:50%;width:10px;height:10px;position:absolute;box-shadow:0 0 4px #0006}.lab-map-mock-banner{width:min(90%,480px);position:absolute;bottom:1.5rem;left:50%;transform:translate(-50%)}.lab-map-mock-banner .map-welcome-banner{width:100%;animation:.3s cubic-bezier(.22,1,.36,1) both map-welcome-rise;position:static;bottom:auto;left:auto;transform:none}.lab-map-mock-dismissed{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);text-align:center;color:var(--text-muted);font-size:var(--text-sm);padding:1.5rem}.claim-ancestry-block{background:var(--bg-surface-alt);border:1px dashed var(--canon-gold);border-radius:var(--radius-md);margin-top:1.25rem;padding:1rem 1.1rem}.claim-ancestry-trigger{appearance:none;background:var(--canon-gold);color:var(--white);border-radius:var(--radius-pill);font-family:inherit;font-weight:700;font-size:var(--text-base);cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm);border:none;align-items:center;gap:.4rem;padding:.55rem 1.1rem;display:inline-flex}.claim-ancestry-trigger:hover{background:var(--canon-gold-strong);box-shadow:var(--shadow-md);transform:translateY(-1px)}.claim-ancestry-trigger:focus-visible{outline:2px solid var(--canon-gold-strong);outline-offset:2px;border-radius:var(--radius-pill)}.claim-ancestry-hint{font-size:var(--text-sm);color:var(--text-muted);margin:.6rem 0 0;font-style:italic;line-height:1.55}.claim-ancestry-hint strong{color:var(--canon-gold-strong);font-style:normal;font-weight:700}.claim-ancestry-actions{align-items:stretch;gap:.65rem;display:flex}.claim-ancestry-trigger{flex:1;justify-content:center}.claim-ancestry-tree-trigger{appearance:none;color:var(--canon-gold-strong);border:1px solid var(--canon-gold);border-radius:var(--radius-sm);font-family:inherit;font-weight:700;font-size:var(--text-sm);cursor:pointer;transition:var(--transition);background:0 0;flex:1;justify-content:center;align-items:center;gap:.3rem;padding:.5rem .95rem;display:inline-flex}.claim-ancestry-tree-trigger:hover{background:var(--canon-gold);color:#fff}.claim-ancestry-admin-trigger{appearance:none;color:var(--terracotta);border:1px dashed var(--terracotta);border-radius:var(--radius-sm);font-family:inherit;font-weight:700;font-size:var(--text-sm);cursor:pointer;transition:var(--transition);background:0 0;flex:1;justify-content:center;align-items:center;gap:.3rem;padding:.5rem .95rem;display:inline-flex}.claim-ancestry-admin-trigger:hover{background:var(--terracotta);color:#fff;border-style:solid}.removed-by-moderation-banner{background:var(--error-bg);border:1px solid var(--error-border);border-left:4px solid var(--error);border-radius:var(--radius-md);color:var(--text-main);margin:.75rem 1rem .5rem;padding:1rem 1.1rem .9rem}.removed-by-moderation-eyebrow{font-size:var(--text-sm);letter-spacing:.08em;text-transform:uppercase;color:var(--error);align-items:center;gap:.4rem;margin:0 0 .4rem;font-weight:800;display:flex}.removed-by-moderation-body{font-size:var(--text-base);color:var(--text-main);margin:0 0 .5rem;line-height:1.55}.removed-by-moderation-reason{background:var(--bg-surface);border-left:3px solid var(--error);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-style:italic;font-size:var(--text-base);color:var(--text-main);margin:0 0 .6rem;padding:.65rem .85rem;line-height:1.5}.removed-by-moderation-appeal{font-size:var(--text-sm);color:var(--text-muted);margin:0;line-height:1.55}.removed-by-moderation-appeal a{color:var(--error);font-weight:600;text-decoration:underline}.removed-by-moderation-appeal a:hover{color:var(--error-hover)}.cornerstone-block{background:var(--bg-surface-alt);border:1px dashed var(--terracotta);border-radius:var(--radius-md);flex-direction:column;gap:.5rem;margin-top:1.25rem;padding:1rem 1.1rem;display:flex}.cornerstone-block-label{font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--terracotta);font-weight:800;display:block}.cornerstone-btn{appearance:none;color:var(--terracotta);border:1px solid var(--terracotta);font-family:inherit;font-weight:700;font-size:var(--text-sm);cursor:pointer;transition:var(--transition);background:0 0;border-radius:999px;align-self:flex-start;align-items:center;gap:.4rem;padding:.55rem 1rem;display:inline-flex}.cornerstone-btn:hover:not(:disabled),.cornerstone-btn.is-pinned{background:var(--terracotta);color:var(--white)}.cornerstone-btn.is-pinned:hover:not(:disabled){background:var(--terracotta-hover,#cf6348)}.cornerstone-btn:disabled{opacity:.65;cursor:wait}.cornerstone-hint{font-size:var(--text-sm);color:var(--text-muted);margin:0;font-style:italic;line-height:1.55}.cornerstone-hint strong{color:var(--terracotta);font-style:normal;font-weight:700}.history-text{font-family:var(--font-main);font-size:var(--text-md);color:var(--text-muted);white-space:pre-wrap;margin-top:1rem;line-height:1.8}.history-text--empty{color:var(--text-muted);opacity:.7;font-style:italic}.history-read-more{font-family:var(--font-main);font-size:var(--text-sm);color:var(--terracotta);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;margin-top:.15rem;padding:.25rem 0;text-decoration:underline;display:block}.history-read-more:hover{color:var(--terracotta-text)}.lineage-deepened-marker{background:var(--terracotta-tint);border-left:3px solid var(--terracotta);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:var(--text-sm);color:var(--text-main);margin:.75rem 0 0;padding:.55rem .85rem;line-height:1.45}.lineage-deepened-marker strong{color:var(--terracotta);font-weight:700}.ai-btn{background:var(--bg-surface-alt);border:1px solid var(--border-color);color:var(--text-main);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);align-items:center;gap:.5rem;margin-bottom:1rem;padding:.6rem 1.25rem;font-weight:700;display:inline-flex}.ai-btn:hover{background:var(--sage);color:#fff;transform:translateY(-1px)}.ai-status{font-family:var(--font-accent);color:var(--text-muted);padding:1rem 0;font-style:italic}.close-btn,.resize-btn,.minimize-btn,.share-btn,.report-flag-btn.header-icon{background:var(--bg-surface);border:1px solid var(--border-color);cursor:pointer;width:32px;height:32px;transition:var(--transition);font-size:var(--text-base);border-radius:50%;justify-content:center;align-items:center;display:flex}.resize-btn:hover,.minimize-btn:hover,.share-btn:hover{background:var(--bg-surface-alt);border-color:var(--text-muted);transform:scale(1.1)}.minimize-btn{display:none}.close-btn:hover{background:var(--error-bg-subtle);color:var(--error)}.report-flag-btn.header-icon{color:var(--text-muted);justify-content:center;padding:0}.report-flag-btn.header-icon:hover{background:var(--bg-surface-alt);border-color:var(--text-muted);color:var(--text-main);transform:scale(1.1)}.detail-title-group h2{font-family:var(--font-accent);color:var(--text-main);word-break:break-word;overflow-wrap:anywhere;margin:.25rem 0 .75rem;font-size:2.2rem;line-height:1.1}.recipe-tag{color:var(--terracotta);text-transform:uppercase;font-weight:700;font-size:var(--text-xs);letter-spacing:.07em;display:block}.recipe-original-name{font-family:var(--font-accent);font-size:var(--text-lg);color:var(--text-muted);word-break:break-word;overflow-wrap:anywhere;text-align:start;margin:.25rem 0 .1rem;line-height:1.2;display:block}.recipe-lang-pill{font-family:var(--font-main);font-size:var(--text-xs);letter-spacing:.06em;background:var(--bg-surface-alt,#0000000a);border:1px solid var(--border-color);color:var(--text-muted);vertical-align:middle;border-radius:999px;margin-left:.5rem;padding:.05rem .4rem;font-weight:700;display:inline-block}.detail-lang-toggle{border:1px solid var(--border-color);border-radius:var(--radius-pill);background:var(--bg-surface-alt,#0000000a);align-items:center;gap:.25rem;margin:0 0 1rem;padding:.2rem;display:inline-flex}.detail-lang-toggle-btn{appearance:none;font-family:inherit;font-size:var(--text-sm);color:var(--text-muted);cursor:pointer;border-radius:var(--radius-pill);background:0 0;border:none;padding:.3rem .85rem;font-weight:600;transition:all .12s}.detail-lang-toggle-btn:hover{color:var(--text-main)}.detail-lang-toggle-btn.is-active{background:var(--terracotta);color:var(--white,#fff)}.detail-original-lang ul{margin:0;padding-left:1.4rem}.detail-original-lang li{margin-bottom:.3rem;line-height:1.55}.detail-original-lang p{margin:0 0 .6rem}.detail-archivist-note{background:var(--sage-tint,#52665e14);border-left:3px solid var(--sage,#52665e);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:var(--text-base);color:var(--text-main);margin:0 0 1rem;padding:.65rem .9rem;font-style:italic;line-height:1.55}.detail-archivist-note-label{letter-spacing:.02em;color:var(--sage-deep,var(--sage,#52665e));font-style:normal;font-weight:700}.detail-context-note{background:var(--terracotta-tint,#e170550f);border-left:3px solid var(--terracotta,#e17055);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:var(--text-base);color:var(--text-main);margin:0 0 1rem;padding:.65rem .9rem;line-height:1.55}.detail-context-note-label{letter-spacing:.02em;color:var(--terracotta,#e17055);margin-right:.15rem;font-weight:700}.detail-source-footer{border-top:1px dashed var(--border-color);font-size:var(--text-sm);color:var(--text-muted);margin:1.5rem 0 0;padding-top:.85rem;font-style:italic;line-height:1.5}.recipe-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin:-.35rem 0 .6rem;font-style:italic;line-height:1.4;display:block}.recipe-etymology{border-left:2px solid var(--sage-light);font-family:var(--font-accent);font-size:var(--text-sm);color:var(--text-main);align-items:baseline;gap:.4rem;margin:.4rem 0 .7rem;padding-left:.7rem;line-height:1.5;display:flex}.recipe-etymology-glyph{opacity:.75;flex-shrink:0;font-size:.85em}.recipe-etymology em{font-style:italic}.detail-meta{flex-wrap:wrap;align-items:baseline;gap:1rem 1.5rem;margin-top:.85rem;display:flex}.detail-action-row{border-top:1px dashed var(--border-color);border-bottom:1px dashed var(--border-color);flex-direction:column;gap:.85rem;margin-top:1.25rem;padding:1rem 0;display:flex}.detail-meta-header{border-bottom:1px solid var(--gray-light);flex-wrap:wrap;margin-bottom:1.5rem;padding:0 0 1.5rem}.kitchen-quick-stats{background:var(--bg-surface-alt);border:1px solid var(--border-color);border-radius:var(--radius-md);gap:1rem 2.5rem;margin-bottom:1.5rem;padding:1.25rem 1.5rem}.kitchen-quick-stats.detail-meta-header{border-bottom:1px solid var(--border-color)}.kitchen-quick-stats .detail-meta-value{font-variant-numeric:tabular-nums}.detail-meta-item{flex-direction:column;gap:.1rem;display:flex}.detail-meta-item--full{width:100%}.detail-meta-label{font-size:var(--text-2xs);color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;opacity:.7;font-weight:700}.detail-meta-value{font-size:var(--text-sm);color:var(--text-main);font-weight:600}.kitchen-quick-stats .detail-meta-label{opacity:1;font-size:var(--text-2xs)}.kitchen-quick-stats .detail-meta-value{font-size:var(--text-base)}.detail-meta-source{font-size:var(--text-xs);color:var(--text-muted);margin-top:.1rem;font-style:italic;font-weight:400;line-height:1.3;display:block}.detail-meta-source cite{color:var(--text-main);font-style:normal;font-weight:500}.detail-meta-legacy{color:var(--text-muted);font-style:italic}.detail-meta-source-link{color:inherit;border-bottom:1px dotted var(--border-color-strong,var(--text-muted));text-decoration:none}.detail-meta-source-link:hover,.detail-meta-source-link:focus-visible{color:var(--terracotta);border-bottom-color:var(--terracotta)}.meta-divider{background:var(--border-color);width:1px;height:1.5rem}.detail-occasion-chips{flex-wrap:wrap;gap:.35rem;margin-top:.2rem;display:flex}.detail-occasion-chip{background:var(--sage-alpha-20);border:1px solid var(--sage);border-radius:var(--radius-pill);font-size:var(--text-sm);color:var(--text-main);align-items:center;gap:.3rem;padding:.25rem .6rem;font-weight:600;display:inline-flex}.detail-last-cooked{font-size:var(--text-sm);color:var(--text-muted);margin:.75rem 0 1.25rem}.detail-meta-link{appearance:none;font:inherit;color:var(--text-main);text-align:left;cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition);background:0 0;border:none;margin:0;padding:0}.detail-meta-link:hover,.detail-meta-link:focus-visible{color:var(--terracotta);text-underline-offset:3px;text-decoration:underline;text-decoration-thickness:1.5px}.detail-meta-link:focus-visible{outline-offset:2px}.detail-tabs{border-bottom:1px solid var(--border-color);background:0 0;gap:2rem;padding:0 2rem;display:flex}.tab-btn{font-family:var(--font-main);font-weight:700;font-size:var(--text-base);color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:3px solid #0000;border-radius:0;flex:none;padding:1rem .25rem;transition:color .18s,border-color .18s}.tab-btn:hover{color:var(--text-main)}.tab-btn.active{color:var(--terracotta);border-bottom-color:var(--terracotta);box-shadow:none;background:0 0}.tab-btn:focus-visible{outline-offset:2px;border-radius:var(--radius-xs)}.detail-tabs--full{gap:0;padding:0}.detail-tabs--full .tab-btn{text-align:center;font-size:var(--text-md);letter-spacing:.01em;flex:1 1 0;padding:.9rem 1rem}.detail-tabs--full .tab-btn.active{background:var(--terracotta-tint)}.detail-body{padding:2.5rem 2rem 1.5rem}.history-text{font-family:var(--font-main);font-size:var(--text-md);color:var(--text-muted);white-space:pre-line;line-height:1.7}.origin-section{background:var(--bg-surface-alt);border-radius:var(--radius-md);border:1px solid var(--border-color);margin-bottom:2.5rem;padding:1.5rem}.origin-grid{grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:1.5rem;display:grid}.origin-item{flex-direction:column;gap:.25rem;display:flex}.origin-label{font-size:var(--text-2xs);color:var(--text-muted);letter-spacing:.08em;font-weight:800}.origin-value{font-size:var(--text-md);color:var(--text-main);font-weight:600}.origin-value-link{background:color-mix(in srgb, var(--sage-light) 14%, transparent);border:1px dashed color-mix(in srgb, var(--sage-light) 50%, var(--border-color));border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-md);color:var(--text-main);text-align:left;align-items:center;gap:.4rem;padding:.45rem .75rem;font-family:inherit;font-weight:600;text-decoration:none;transition:background .18s,border-color .18s;display:inline-flex}.origin-value-link:hover,.origin-value-link:focus-visible{background:color-mix(in srgb, var(--sage-light) 24%, transparent);border-color:color-mix(in srgb, var(--sage-light) 75%, var(--border-color));text-decoration:none}.ancestry-track{border-top:1px solid var(--border-color);padding-top:1.25rem}.track-label{font-size:var(--text-2xs);color:var(--text-muted);letter-spacing:.08em;margin-bottom:.75rem;font-weight:800;display:block}.track-flow{align-items:center;gap:1rem;display:flex}.track-point{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-main);padding:.5rem 1rem;font-weight:600;line-height:1.4}.track-point.root{background:var(--sage-alpha-20);border-color:var(--sage-light)}.track-point.current{background:var(--bg-surface);border-color:var(--border-color-strong)}.track-arrow{color:var(--text-muted);font-size:var(--text-lg);font-weight:600}.detail-section h3{font-family:var(--font-accent);color:var(--text-main);font-size:var(--text-xl);border-bottom:1px solid var(--sage-alpha-20);margin-bottom:1rem;padding-bottom:.6rem}.detail-body .detail-section+.detail-section{margin-top:2rem}.ingredients-list{grid-template-columns:1fr 1fr;gap:.75rem;list-style:none;display:grid}.ingredients-list li{background:var(--bg-surface-alt);border-radius:var(--radius-xs);font-size:var(--text-base);padding:.5rem}.detail-footer{background:var(--bg-surface-alt);border-top:1px solid var(--border-color);padding:1.5rem}.footer-group{align-items:center;gap:1rem;width:100%;display:flex}.list-page-container{padding:3rem var(--space-md);flex:1;width:100%;max-width:1400px;margin:0 auto;overflow-y:auto}.recipe-container.grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:3rem;display:grid}.recipe-item-card{background:var(--bg-surface);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);overflow:hidden}.recipe-item-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-8px)}.edit-modal-overlay{background:var(--bg-surface);z-index:20000;animation:.2s ease-out fadeIn;position:fixed;inset:0}.edit-modal-content{background:var(--bg-surface);width:100%;max-width:none;height:100dvh;max-height:none;box-shadow:none;border:none;border-radius:0;flex-direction:column;display:flex;overflow:hidden}.edit-modal-header{background:var(--bg-surface-alt);border-bottom:1px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:center;padding:1.25rem 2rem;display:flex}.modal-label{font-size:var(--text-sm);color:var(--text-main);letter-spacing:.01em;margin-bottom:.25rem;font-weight:700;display:block}.edit-modal-header h1{font-family:var(--font-accent);font-size:var(--text-2xl);color:var(--text-main)}.modal-close-btn{background:var(--bg-surface);border:1px solid var(--border-color);width:48px;height:48px;font-size:var(--text-xl);cursor:pointer;transition:var(--transition);border-radius:50%;justify-content:center;align-items:center;display:flex}.modal-close-btn:hover{background:var(--error-bg-subtle);color:var(--error);transform:rotate(90deg)}.edit-modal-form{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}@media (width>=900px){.edit-modal-form{grid-template:"nav content"1fr"footer footer"/200px 1fr;display:grid}}.edit-grid{flex:1;grid-template-columns:1fr 1fr;gap:3rem;padding:3rem;display:grid;overflow-y:auto}.edit-section h3,.edit-section .edit-section-title{font-family:var(--font-accent);font-size:var(--text-xl);color:var(--text-main);border-bottom:2px solid var(--border-color);margin-bottom:1.5rem;padding-bottom:.5rem;font-weight:700}.edit-modal-form .edit-section{background:var(--bg-surface-alt);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:1.5rem;padding:1.5rem 1.75rem}.edit-modal-form .edit-section:last-child{margin-bottom:0}.edit-modal-form .edit-section h3{border-bottom:none;margin-bottom:.4rem;padding-bottom:0}.edit-modal-form .section-header{margin-bottom:1.25rem}.edit-modal-form .section-header p{color:var(--text-muted);font-size:var(--text-sm);margin:0;line-height:1.5}.edit-modal-form .image-manager{background:0 0;border:none;border-radius:0;padding:0}.edit-modal-form .edit-section.gallery-top{background:var(--bg-surface-alt);padding:1.5rem 1.75rem}.edit-modal-footer{background:var(--bg-surface-alt);border-top:1px solid var(--border-color);flex-shrink:0;align-items:center;padding:1.25rem 2rem;display:flex}@media (width>=900px){.edit-modal-footer{grid-area:footer}}.edit-modal-tabs{background:var(--bg-surface-alt);border-bottom:1px solid var(--border-color);flex-shrink:0;gap:1.5rem;padding:0 1.5rem;display:flex}.modal-tab-btn{font-family:var(--font-main);font-weight:700;font-size:var(--text-base);color:var(--text-muted);cursor:pointer;transition:var(--transition);white-space:nowrap;background:0 0;border:none;border-bottom:3px solid #0000;padding:1rem .25rem}.modal-tab-btn:hover{color:var(--text-main)}.modal-tab-btn.active{color:var(--terracotta);border-bottom-color:var(--terracotta)}@media (width>=900px){.edit-modal-tabs{background:var(--bg-surface-alt);border-bottom:none;border-right:1px solid var(--border-color);flex-direction:column;grid-area:nav;align-items:stretch;gap:.25rem;padding:1.5rem .75rem;overflow-y:auto}.modal-tab-btn{text-align:left;font-size:var(--text-sm);border-radius:var(--radius-sm);border-bottom:none;border-left:3px solid #0000;padding:.75rem 1rem;transition:background .18s,color .18s,border-color .18s}.modal-tab-btn:hover:not(.active){color:var(--text-main);background:#8ba89e14}.modal-tab-btn.active{border-bottom-color:#0000;border-left-color:var(--terracotta);background:var(--bg-surface);color:var(--terracotta);box-shadow:var(--shadow-sm)}.modal-tab-btn:focus-visible{outline-offset:2px}}.single-column{width:100%;max-width:820px;margin:0 auto;grid-template-columns:1fr!important}.edit-tab-pane{box-sizing:border-box;max-width:880px;margin:0 auto;padding:2rem 2.5rem;animation:.3s ease-out fadeIn}.edit-tab-pane .edit-grid.single-column{max-width:none;padding:0}.image-manager{background:var(--bg-surface-alt);border-radius:var(--radius-md);border:1px solid var(--border-color);padding:1.5rem}.image-input-group{gap:.5rem;margin-bottom:1.5rem;display:flex}.image-input-group input{border:1px solid var(--border-color);border-radius:var(--radius-sm);font-family:var(--font-main);flex:1;padding:.8rem 1rem}.add-img-btn{background:var(--sage);color:var(--white);border-radius:var(--radius-sm);font-weight:700;font-size:var(--text-base);cursor:pointer;white-space:nowrap;transition:var(--transition);border:none;padding:.65rem 1.25rem}.add-img-btn:hover{background:var(--sage-deep)}.add-img-btn.upload{background:var(--terracotta)}.divider-v{background:var(--gray-light);width:1px;margin:0 .5rem}.edit-image-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem;display:grid}.edit-image-item{aspect-ratio:1;border-radius:var(--radius-sm);border:1px solid var(--border-color);position:relative;overflow:hidden}.remove-img-btn{appearance:none;color:#fff;border-radius:var(--radius-pill);font-size:var(--text-xs);cursor:pointer;white-space:nowrap;background:#000000a6;border:1px solid #fff3;align-items:center;gap:.35rem;padding:.3rem .85rem;font-family:inherit;font-weight:600;transition:background .12s;display:flex}.gallery-top{padding:2rem 3rem}.edit-image-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.edit-image-item{aspect-ratio:4/3;border-radius:var(--radius-md);background:var(--bg-surface);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);transition:var(--transition);position:relative;overflow:hidden}.edit-image-item:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}.edit-image-item img{object-fit:cover;width:100%;height:100%}.edit-image-item.add-card{border:2px dashed var(--sage-light);cursor:pointer;font:inherit;color:inherit;background:#8ba89e0d;justify-content:center;align-items:center;width:100%;padding:0;display:flex}.add-card-content{color:var(--text-main);flex-direction:column;align-items:center;gap:.5rem;font-weight:700;display:flex}.add-icon{font-size:var(--text-2xl)}.image-overlay{opacity:0;transition:var(--transition);background:#0006;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;display:flex;position:absolute;inset:0}.edit-image-item:hover .image-overlay{opacity:1}.set-main-btn{appearance:none;background:var(--terracotta);color:#fff;border-radius:var(--radius-pill);font-size:var(--text-xs);cursor:pointer;letter-spacing:.03em;white-space:nowrap;border:none;padding:.3rem .85rem;font-family:inherit;font-weight:700;transition:background .12s}.set-main-btn:hover{background:var(--terracotta-deep,#b5432a)}.remove-img-btn:hover{background:#aa1e0fd9}.image-badge{background:var(--terracotta);color:var(--white);border-radius:var(--radius-pill);font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;box-shadow:var(--shadow-sm);padding:.25rem .75rem;font-weight:800;position:absolute;top:.75rem;left:.75rem}.image-input-group.footer-input{max-width:600px}.recipe-cleanup-row{justify-content:flex-end;margin:.25rem 0 1.25rem;display:flex}.recipe-cleanup-trigger{appearance:none;border:1px solid var(--border-color);border-radius:var(--radius-pill);color:var(--text-muted);font-size:var(--text-sm);cursor:pointer;background:0 0;align-items:center;gap:.45rem;padding:.45rem 1rem;font-family:inherit;font-weight:500;transition:border-color .15s,color .15s,background .15s;display:inline-flex}.recipe-cleanup-trigger:hover:not(:disabled){border-color:var(--sage);color:var(--sage-deep,#3d6b4a);background:color-mix(in srgb, var(--sage) 8%, transparent)}.recipe-cleanup-trigger:disabled{opacity:.7;cursor:default}.recipe-cleanup-spinner{border:2px solid;border-top-color:#0000;border-radius:50%;flex-shrink:0;width:.85em;height:.85em;animation:.7s linear infinite cleanupSpin;display:inline-block}@keyframes cleanupSpin{to{transform:rotate(360deg)}}.recipe-cleanup-result{border:1px solid var(--sage-light,#b8d0c8);border-left:3px solid var(--sage);border-radius:var(--radius-md);background:color-mix(in srgb, var(--sage) 6%, var(--bg-surface));margin:.25rem 0 1.25rem;padding:1rem 1.25rem;animation:.25s ease-out fadeIn}.recipe-cleanup-result-header{align-items:flex-start;gap:.65rem;display:flex}.recipe-cleanup-icon{flex-shrink:0;font-size:1.25rem;line-height:1.4}.recipe-cleanup-summary{font-size:var(--text-sm);color:var(--text-main);flex:1;margin:0;line-height:1.5}.recipe-cleanup-actions{gap:.6rem;margin-top:.85rem;display:flex}.recipe-cleanup-btn{appearance:none;border-radius:var(--radius-sm,6px);font-size:var(--text-sm);cursor:pointer;border:1px solid #0000;padding:.35rem .9rem;font-family:inherit;font-weight:600;transition:background .12s,border-color .12s}.recipe-cleanup-btn-apply{background:var(--sage);color:#fff}.recipe-cleanup-btn-apply:hover{background:var(--sage-deep,#3d6b4a)}.recipe-cleanup-btn-dismiss{background:var(--bg-surface);border-color:var(--border-color);color:var(--text-muted)}.recipe-cleanup-btn-dismiss:hover{background:var(--bg-surface-alt);color:var(--text-main)}.cleanup-diff-section{border-top:1px solid var(--border-color);margin:.75rem 0 0;padding-top:.75rem}.cleanup-diff-section-label{font-size:var(--text-xs,.75rem);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin:0 0 .5rem;font-weight:600}.cleanup-diff-table{flex-direction:column;gap:.35rem;display:flex}.cleanup-diff-row{font-size:var(--text-sm);flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.cleanup-diff-ing{border-radius:var(--radius-sm,6px);flex-wrap:wrap;flex:1;align-items:center;gap:.3rem;min-width:0;padding:.2rem .45rem;display:inline-flex}.cleanup-diff-ing-before{background:color-mix(in srgb, var(--terracotta,#c0614f) 10%, transparent);color:var(--text-main)}.cleanup-diff-ing-after{background:color-mix(in srgb, var(--sage,#5a8a6a) 12%, transparent);color:var(--text-main)}.cleanup-diff-chip{background:var(--bg-surface-alt);white-space:nowrap;color:var(--text-main);border-radius:4px;padding:.05rem .35rem;font-size:.78rem;font-weight:600}.cleanup-diff-ing-before .cleanup-diff-chip{background:color-mix(in srgb, var(--terracotta,#c0614f) 18%, var(--bg-surface))}.cleanup-diff-ing-after .cleanup-diff-chip{background:color-mix(in srgb, var(--sage,#5a8a6a) 18%, var(--bg-surface))}.cleanup-diff-ing-name{font-size:var(--text-sm);text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.cleanup-diff-notes{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-style:italic;overflow:hidden}.cleanup-diff-arrow{color:var(--text-muted);font-size:var(--text-base);flex-shrink:0}.cleanup-diff-text-note{font-size:var(--text-sm);color:var(--text-secondary);margin:.2rem 0 0}.cleanup-diff-no-changes{font-size:var(--text-sm);color:var(--text-muted);margin:.5rem 0 0;font-style:italic}.cleanup-diff-empty{color:var(--text-muted)}.image-gallery{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.image-gallery img{aspect-ratio:1;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border-color);width:100%;box-shadow:var(--shadow-sm)}.edit-scroll-container{flex:1;min-height:0;overflow-y:auto}@media (width>=900px){.edit-scroll-container{grid-area:content}}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.collection-switcher{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);gap:.3rem;padding:.4rem;display:flex}.collection-item{border-radius:var(--radius-lg);color:var(--text-main);cursor:pointer;transition:var(--transition);background:0 0;border:none;padding:.6rem 1.4rem;font-weight:700}.collection-item.active{background:var(--sage);color:var(--white)}.ai-research-container{border-radius:var(--radius-md);border:1px dashed var(--sage-light);background:linear-gradient(135deg,#52665e0d 0%,#e170550d 100%);flex-direction:column;gap:.75rem;margin-bottom:2rem;padding:1.5rem;display:flex}.ai-research-btn{background:linear-gradient(135deg, var(--sage) 0%, var(--sage-deep) 100%);color:#fff;border-radius:var(--radius-sm);font-family:var(--font-main);cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm);border:none;justify-content:center;align-items:center;gap:.75rem;padding:.8rem 1.5rem;font-weight:700;display:flex}.ai-research-btn:hover:not(:disabled){box-shadow:var(--shadow-md);background:linear-gradient(135deg, var(--sage-deep) 0%, #1e272e 100%);transform:translateY(-2px)}.ai-research-btn:disabled{opacity:.8;cursor:not-allowed}.ai-hint{font-size:var(--text-sm);color:var(--text-main);margin:0;font-style:italic}.ai-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.user-profile{align-items:center;display:flex;position:relative}.user-initial-btn{background:var(--sage);color:#fff;border:2px solid var(--cream);width:40px;height:40px;font-family:var(--font-accent);font-weight:700;font-size:var(--text-lg);cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm);border-radius:50%;justify-content:center;align-items:center;display:flex}.user-initial-btn:hover{background:var(--sage-deep);box-shadow:var(--shadow-md);transform:scale(1.05)}.profile-dropdown{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);width:220px;box-shadow:var(--shadow-lg);z-index:1000;padding:.5rem 0;animation:.3s cubic-bezier(.4,0,.2,1) slideDownFade;position:absolute;top:calc(100% + 12px);right:0}.dropdown-header{border-bottom:1px solid var(--border-color);margin-bottom:.5rem;padding:.75rem 1.25rem}.user-email{font-size:var(--text-xs);color:var(--text-muted);word-break:break-all;font-weight:600}.dropdown-item{width:100%;color:var(--text-muted);font-weight:700;font-size:var(--text-base);cursor:pointer;transition:var(--transition);text-align:left;background:0 0;border:none;align-items:center;gap:.75rem;padding:.75rem 1.25rem;display:flex}.dropdown-item:hover{background:var(--bg-surface-alt);color:var(--terracotta)}.dropdown-item .icon{font-size:var(--text-lg)}.dropdown-item-badge{background:var(--terracotta);color:#fff;min-width:1.1rem;height:1.1rem;font-size:var(--text-xs);border-radius:999px;justify-content:center;align-items:center;margin-left:auto;padding:0 .4rem;font-weight:700;line-height:1;display:inline-flex}.dropdown-divider{background:var(--border-color);height:1px;margin:.5rem 0}.dropdown-theme{padding:.5rem .85rem .65rem}.dropdown-theme-label{font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.5rem;font-weight:800;display:block}.dropdown-theme-buttons{background:var(--bg-surface-alt);border-radius:var(--radius-sm);grid-template-columns:repeat(3,1fr);gap:.35rem;padding:.25rem;display:grid}.dropdown-theme-btn{border-radius:calc(var(--radius-sm) - 2px);font-family:inherit;font-size:var(--text-xs);color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;border:1px solid #0000;flex-direction:column;justify-content:center;align-items:center;gap:.2rem;padding:.5rem .25rem;font-weight:600;display:flex}.dropdown-theme-btn:hover{color:var(--text-main);background:var(--bg-surface)}.dropdown-theme-btn.active{background:var(--bg-surface);color:var(--sage);border-color:var(--sage-light);box-shadow:var(--shadow-sm)}.dropdown-theme-name{font-size:var(--text-xs)}.dropdown-item.logout{color:var(--error)}.dropdown-item.logout:hover{background:var(--error-bg-subtle)}.heritage-popup{min-width:220px;padding:.5rem}.popup-step-counter{font-size:var(--text-2xs);color:var(--terracotta);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem;font-weight:800;display:block}.heritage-popup strong{font-family:var(--font-main);font-size:var(--text-base);color:var(--text-main);margin-bottom:.5rem;display:block}.heritage-popup p{font-size:var(--text-sm);color:var(--text-muted);line-height:1.4;margin-bottom:1rem!important}.popup-nav{border-top:1px solid var(--border-color);gap:.5rem;padding-top:.75rem;display:flex}.pop-nav-btn{background:var(--bg-surface-alt);border:1px solid var(--border-color);border-radius:var(--radius-xs);font-size:var(--text-xs);color:var(--text-muted);cursor:pointer;transition:var(--transition);flex:1;padding:.5rem;font-weight:700}.pop-nav-btn:hover:not(:disabled){background:var(--sage);color:#fff;border-color:var(--text-main)}.pop-nav-btn:disabled{opacity:.3;cursor:not-allowed}.map-marker-photo-wrapper{background:0 0!important;overflow:visible!important}.map-marker-photo{transform-origin:50%;cursor:pointer;background-position:50%;background-size:cover;border:2.5px solid #fff;border-radius:50%;width:44px;height:44px;transition:transform .18s,box-shadow .18s;box-shadow:0 2px 8px #00000073}.map-marker-photo:hover{z-index:1000;transform:scale(1.15);box-shadow:0 6px 20px #0000008c}.heritage-popup-wrapper .leaflet-popup-content-wrapper{background:var(--bg-surface);color:var(--text-main);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:1px solid var(--border-color)}.heritage-popup-wrapper .leaflet-popup-content{margin:12px 16px}.heritage-popup-wrapper .leaflet-popup-tip{background:var(--bg-surface)}:root{--sidebar-width:400px;--detail-width:440px;--detail-expanded-width:850px}@media (width<=1024px){:root{--detail-expanded-width:100%;--sidebar-width:0px;--detail-width:100%}.nav-container{padding:0 1rem}.nav-header-actions{order:0;margin-right:.75rem}.profile-dropdown{position:fixed;top:72px;left:auto;right:1rem}.nav-toggle,.nav-links,.nav-backdrop{display:none!important}.bottom-tab-bar{height:calc(56px + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:var(--bg-surface);border-top:1px solid var(--border-color);z-index:19998;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 12px #00000014}.bottom-tab-item{color:var(--text-muted);font-family:var(--font-main);letter-spacing:.01em;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:6px 4px 4px;font-size:11px;font-weight:500;text-decoration:none;transition:color .15s;display:flex;position:relative}.bottom-tab-item.active{color:var(--terracotta)}.bottom-tab-item:active{opacity:.65}.bottom-tab-icon{justify-content:center;align-items:center;display:flex;position:relative}.bottom-tab-label{line-height:1}.bottom-tab-badge{background:var(--terracotta);min-width:15px;height:15px;color:var(--white);text-align:center;pointer-events:none;border-radius:999px;padding:0 3px;font-size:9px;font-weight:800;line-height:15px;position:absolute;top:-5px;right:-8px}.bottom-tab-item--add{justify-content:center}.bottom-tab-add-circle{background:var(--terracotta);width:46px;height:46px;color:var(--white);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:-12px;display:flex;box-shadow:0 3px 10px #00000038}.bottom-tab-item--add:active .bottom-tab-add-circle{background:var(--terracotta-hover);opacity:1;transform:scale(.95)}.sidebar-scroll{padding-bottom:calc(56px + env(safe-area-inset-bottom,0px) + 1rem)!important}.detail-panel:not(.page-mode):not(.modal-mode) .detail-body{padding-bottom:calc(2rem + env(safe-area-inset-bottom,0px))!important}.detail-panel.page-mode .detail-body,.detail-panel.modal-mode .detail-body{padding-bottom:calc(56px + env(safe-area-inset-bottom,0px) + 1.5rem)!important}.list-page-container{padding-bottom:calc(56px + env(safe-area-inset-bottom,0px) + 1rem)!important}.subscribe-page,.profile-page,.profile-edit-page,.family-page-root,.join-page,.add-recipe-container,.recipe-page-container,.about-page,.marketing-page,.login-page,.admin-mod-page,.support-page{padding-bottom:calc(56px + env(safe-area-inset-bottom,0px))!important}.map-sidebar{left:0;bottom:calc(56px + env(safe-area-inset-bottom,0px));z-index:10005;height:85dvh;transform:translateY(calc(100% - 60px + var(--sheet-drag,0px)));border-right:none;border-top:1px solid var(--border-color);border-radius:var(--radius-lg) var(--radius-lg) 0 0;transition:transform .4s cubic-bezier(.175,.885,.32,1.275);position:fixed;width:100%!important;animation:none!important;top:auto!important}.map-sidebar.mobile-expanded{transform:translateY(var(--sheet-drag,0px))}.map-sidebar.sidebar-recipe-open{pointer-events:none!important;transition:none!important;transform:translateY(100%)!important}.map-sidebar.dragging{transition:none!important}.map-sidebar.dragging .sidebar-scroll{pointer-events:none}.map-sidebar .sidebar-scroll{padding-bottom:calc(2rem + env(safe-area-inset-bottom,0px))!important}.sheet-handle-zone{cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.dragging .sheet-handle-zone{cursor:grabbing}.sidebar-header{padding:.5rem 1.25rem!important}.sidebar-control-main{flex-direction:row!important;align-items:center!important;gap:.4rem!important;padding:0 .75rem .75rem!important;display:flex!important}.sidebar-control-main .btn-label{display:none}.sidebar-control-main .lucky-btn,.sidebar-control-main .filter-toggle-btn{border-radius:var(--radius-sm)!important;flex-shrink:0!important;justify-content:center!important;width:38px!important;min-width:38px!important;height:38px!important;padding:.55rem!important}.sidebar-control-main .sidebar-search input{font-size:var(--text-sm)!important;padding:.55rem .75rem .55rem 2rem!important}.sidebar-collection-top{padding:.75rem .75rem .4rem!important}.sidebar-filters{flex-direction:column!important;gap:.75rem!important;display:flex!important}.sidebar-filters select{flex:none!important;width:100%!important;max-width:none!important}.sidebar-controls{flex:0 auto;min-height:0;max-height:65dvh;overflow-y:auto}.collection-switcher{-webkit-overflow-scrolling:touch;scrollbar-width:none;white-space:nowrap!important;justify-content:flex-start!important;gap:.75rem!important;width:100%!important;padding:.5rem .25rem!important;display:flex!important;overflow-x:auto!important}.collection-switcher::-webkit-scrollbar{display:none}.collection-btn{flex:none!important;min-width:fit-content!important;padding:.5rem 1rem!important}.sheet-handle{background:var(--border-color);border-radius:var(--radius-sm);width:40px;height:5px;margin:.5rem auto;display:block}.sidebar-filters{flex-direction:column!important;width:100%!important;display:flex!important}.sidebar-filters select{width:100%!important;margin-bottom:.5rem!important;display:block!important}.detail-panel.open{bottom:calc(56px + env(safe-area-inset-bottom,0px));border-radius:var(--radius-lg) var(--radius-lg) 0 0;border-left:none;border-top:1px solid var(--border-color);z-index:10010;height:85dvh;transform:translateY(calc(45vh + var(--sheet-drag,0px)));transition:transform .4s cubic-bezier(.175,.885,.32,1.275);position:fixed;left:0;width:100%!important}.detail-panel.open.mobile-expanded{transform:translateY(var(--sheet-drag,0px))}.detail-panel.modal-mode.open,.detail-panel.page-mode.open{border-top:none;border-radius:0;max-width:none;height:100dvh;transition:none;top:0;transform:none}.detail-panel.page-mode.open{height:auto;position:relative;bottom:auto;left:auto}.detail-panel.page-mode .sheet-handle-zone{display:none}.detail-body{padding-bottom:calc(2rem + env(safe-area-inset-bottom,0px))!important}.detail-panel.dragging{transition:none!important}.detail-panel.dragging .detail-body{pointer-events:none}.detail-panel .resize-btn{display:none}.detail-panel.open.mobile-minimized{pointer-events:none;transform:translateY(100%)}.detail-mini-pill{z-index:10011;background:var(--bg-surface);border-top:1px solid var(--border-color);box-shadow:var(--shadow-timeline);align-items:center;gap:.5rem;padding:.75rem 1rem;animation:.25s ease-out pillSlideUp;display:flex;position:fixed;bottom:0;left:0;right:0}.detail-mini-pill-body{color:var(--text-main);font-family:inherit;font-size:var(--text-base);text-align:left;cursor:pointer;background:0 0;border:none;flex:1;align-items:center;gap:.6rem;min-width:0;padding:.4rem .25rem;display:flex}.detail-mini-pill-icon{color:var(--terracotta);font-weight:800;font-size:var(--text-lg);flex-shrink:0}.detail-mini-pill-title{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;min-width:0;font-weight:700;overflow:hidden}.detail-mini-pill-close{color:var(--text-muted);font-size:var(--text-lg);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:.4rem .6rem;display:inline-flex}.detail-mini-pill-close:hover{background:var(--bg-surface-alt)}@keyframes pillSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.detail-panel .minimize-btn{display:flex}.edit-modal-header{gap:.75rem;padding:1rem 1.25rem}.edit-modal-header h1{font-size:var(--text-xl);word-break:break-word;line-height:1.15}.edit-modal-header .modal-label{font-size:var(--text-2xs)}.edit-grid{grid-template-columns:1fr;gap:1.5rem;padding:1.25rem}.edit-modal-footer{flex-wrap:wrap;gap:.5rem;padding:.75rem 1rem}}.detail-meta-link{appearance:none;font:inherit;color:inherit;cursor:pointer;text-align:left;background:0 0;border:none;padding:0}.detail-meta-link:hover,.detail-meta-link:focus-visible{color:var(--terracotta);outline:none;text-decoration:underline}.step-images-section{margin-top:1.5rem}.step-images-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem;margin-top:.75rem;display:grid}.step-image-card{border-radius:var(--radius-sm);background:var(--bg-surface-alt);border:1px solid var(--border-subtle);position:relative;overflow:hidden}.step-image-card img{aspect-ratio:4/3;object-fit:cover;width:100%;display:block}.step-badge{background:var(--accent-sage);color:#fff;font-size:var(--text-2xs);letter-spacing:.04em;border-radius:var(--radius-xs);padding:2px 7px;font-weight:700;display:inline-block;position:absolute;top:6px;left:6px}.step-image-row{border-bottom:1px solid var(--border-subtle);align-items:center;gap:.75rem;padding:.5rem 0;display:flex}.step-image-row:last-of-type{border-bottom:none}.step-image-row .step-badge{font-size:var(--text-xs);position:static}.step-image-row img{object-fit:cover;border-radius:var(--radius-xs);flex-shrink:0;width:56px;height:42px}.step-image-row .remove-step-img{color:var(--text-muted);cursor:pointer;font-size:var(--text-sm);background:0 0;border:none;margin-left:auto}.step-image-add{margin-top:.75rem;display:block}.step-image-add>span{font-size:var(--text-sm);color:var(--text-muted);margin-top:.5rem;font-style:italic;display:block}.step-number-input{border:1px solid var(--border-subtle);border-radius:var(--radius-xs);background:var(--bg-surface);width:72px;color:var(--text-primary);font-size:var(--text-sm);padding:.4rem .5rem}.upload-card-inline{border:2px dashed var(--sage-light);border-radius:var(--radius-md);width:100%;min-height:64px;color:var(--text-main);font-family:inherit;font-size:var(--text-base);cursor:pointer;transition:var(--transition);background:#8ba89e0d;justify-content:center;align-items:center;gap:.5rem;padding:.85rem 1rem;font-weight:700;display:flex}.upload-card-inline:hover:not(:disabled){border-color:var(--terracotta);color:var(--terracotta);background:var(--terracotta-tint)}.upload-card-inline:disabled{opacity:.4;cursor:not-allowed}.heritage-photos-section{border-top:1px solid var(--border-color);margin-top:2.5rem;padding-top:1.75rem}.heritage-photos-section h3{font-family:var(--font-accent);margin-bottom:.75rem}.heritage-photos-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;margin-top:.75rem;display:grid}.heritage-photo-figure{border-radius:var(--radius-sm);background:var(--bg-surface-alt);border:1px solid var(--border-subtle);margin:0;overflow:hidden}.heritage-photo-figure img{aspect-ratio:3/2;object-fit:cover;filter:sepia(20%);width:100%;display:block}.heritage-photo-figure figcaption{font-size:var(--text-xs);color:var(--text-muted);padding:.4rem .6rem;font-style:italic}.heritage-photo-item{border-bottom:1px solid var(--border-subtle);flex-direction:column;gap:.4rem;padding:.75rem 0;display:flex}.heritage-photo-item:last-of-type{border-bottom:none}.heritage-photo-item img{object-fit:cover;border-radius:var(--radius-xs);width:100%;max-height:160px}.heritage-photo-item-row{align-items:center;gap:.5rem;display:flex}.heritage-photo-item-row input{border:1px solid var(--border-subtle);border-radius:var(--radius-xs);background:var(--bg-surface);color:var(--text-primary);font-size:var(--text-sm);flex:1;padding:.35rem .5rem}.heritage-photo-year{max-width:90px!important}.remove-heritage-btn{color:var(--text-muted);cursor:pointer;font-size:var(--text-sm);background:0 0;border:none;flex-shrink:0}.fullpage-btn{cursor:pointer;color:var(--text-secondary);font-size:var(--text-md);border-radius:var(--radius-xs);background:0 0;border:none;padding:.25rem .4rem;line-height:1;transition:color .15s}.fullpage-btn:hover{color:var(--text-primary)}.wake-lock-btn{display:none}@media (width<=1024px){.wake-lock-btn{bottom:calc(56px + env(safe-area-inset-bottom,0px) + .6rem);z-index:10020;border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-surface);color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;box-shadow:var(--shadow-sm);align-items:center;gap:.4rem;padding:.45rem .9rem;transition:all .15s;display:flex;position:fixed;right:.75rem}.wake-lock-btn.is-active{background:var(--accent-sage);color:#fff;border-color:var(--accent-sage)}}.lucky-btn{border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-surface);color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;white-space:nowrap;align-items:center;gap:.35rem;padding:.4rem .8rem;transition:all .15s;display:flex}.lucky-btn:hover:not(:disabled){background:var(--accent-sage);color:#fff;border-color:var(--accent-sage)}.lucky-btn:disabled{opacity:.6;cursor:not-allowed}.lucky-spinner{animation:.8s linear infinite spin}.print-btn{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;width:32px;height:32px;font-size:var(--text-md);color:var(--text-muted);transition:var(--transition);flex-shrink:0;justify-content:center;align-items:center;display:flex}.print-btn:hover{background:var(--bg-surface-alt);border-color:var(--text-muted);transform:scale(1.1)}.print-view{display:none}@media print{@page{size:letter portrait;margin:1.1in .9in .9in}body>:not(.print-view){display:none!important}body{background:#fff!important}.print-view{color:#111;font-family:Georgia,Times New Roman,serif;font-size:11pt;line-height:1.55;display:block}.print-header{border-bottom:2pt solid #111;margin-bottom:1.1rem;padding-bottom:.7rem;overflow:hidden}.print-category{letter-spacing:.14em;text-transform:uppercase;color:#888;margin:0 0 .25rem;font-family:Arial,Helvetica,sans-serif;font-size:7.5pt;font-weight:700}.print-title{margin:0 0 .3rem;font-family:Georgia,Times New Roman,serif;font-size:22pt;font-weight:700;line-height:1.1}.print-subtitle{color:#555;margin:0;font-size:10.5pt}.print-photo{float:right;object-fit:cover;border-radius:4pt;max-width:2.6in;max-height:2.2in;margin:0 0 .75rem .9rem}.print-stats{border-bottom:.5pt solid #ccc;gap:1.4rem;margin-bottom:1rem;padding:.4rem 0;font-family:Arial,Helvetica,sans-serif;font-size:9pt;display:flex}.print-section{break-inside:avoid;margin-bottom:1rem}.print-section h2{border-bottom:.5pt solid #ccc;margin:0 0 .3rem;padding-bottom:.15rem;font-family:Georgia,Times New Roman,serif;font-size:12.5pt;font-weight:700}.print-ingredients{columns:2;column-gap:1.5rem;margin:0;padding:0;font-size:10.5pt;list-style:none}.print-ingredients li{break-inside:avoid;padding:.08rem 0}.print-ing-note{color:#666;font-style:italic}.print-instructions{margin:0;padding-left:1.1rem;font-size:10.5pt}.print-instructions li{margin-bottom:.35rem}.print-prose{margin:0;font-size:10.5pt;line-height:1.55}.print-section--history h2{color:#555;font-size:10.5pt}.print-section--history .print-prose{color:#444;font-size:9.5pt}.print-footer{color:#999;margin-top:1.5rem;font-family:Arial,Helvetica,sans-serif;font-size:8pt}.print-footer hr{border:none;border-top:.5pt solid #ccc;margin-bottom:.3rem}}.detail-panel.page-mode .detail-header{z-index:auto!important;background:0 0!important;border-bottom:none!important;position:static!important;top:auto!important}
