@import url("https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;700&family=Lato:wght@300;400;700&display=swap");:root{--primary:#5e445a;--accent:#dc7243;--gold:#dd9d5b;--bg:#fdf6ee}html{font-size:112%}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg);font-family:Lato,sans-serif;color:#3a2a38;min-height:100vh;border-top:5px solid var(--primary);transition:background-color .3s,color .3s}html.dark{--surface:color-mix(in srgb,var(--bg) 85%,white 15%);--raised:color-mix(in srgb,var(--bg) 75%,white 25%);--border:color-mix(in srgb,var(--bg) 70%,white 30%);--text:color-mix(in srgb,var(--bg) 5%,white 95%);--text-soft:color-mix(in srgb,var(--bg) 20%,white 80%);--text-muted:color-mix(in srgb,var(--bg) 40%,white 60%)}html.dark body{color:var(--text);background-color:var(--bg)}html.dark .collection-picker,html.dark .compare-card,html.dark .comparison-box,html.dark .day-column,html.dark .grid-card,html.dark .grocery-panel,html.dark .list-row,html.dark .multiselect-dropdown,html.dark .recipe-card,html.dark .tag-dropdown,html.dark .theme-section,html.dark .unscheduled-pool{background:var(--surface);border-color:var(--border)}html.dark .form-section{border-color:var(--primary)}html.dark .collections-sidebar,html.dark .form-section,html.dark .modal,html.dark .settings-sidebar{background:var(--surface)}html.dark .modal-overlay{background:rgba(0,0,0,.6)}html.dark .modal-header{border-color:var(--border)}html.dark .auth-input,html.dark .collection-picker-input,html.dark .form-input,html.dark .new-collection-input,html.dark .notes-textarea,html.dark .search-input,html.dark .tag-input,html.dark .theme-hex-input{background:var(--raised);border-color:var(--border);color:var(--text)}html.dark .sort-select{background-color:var(--raised);border-color:var(--border);color:var(--text);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23ffffff' d='M6 8L1 3h10z'/%3E%3C/svg%3E")}html.dark .auth-input::placeholder,html.dark .collection-picker-input::placeholder,html.dark .form-input::placeholder,html.dark .new-collection-input::placeholder,html.dark .notes-textarea::placeholder,html.dark .search-input::placeholder,html.dark .tag-input::placeholder{color:var(--text-muted)}html.dark .deselect-btn,html.dark .multiselect-btn,html.dark .scale-btn,html.dark .view-btn{background:var(--raised);border-color:var(--border);color:var(--text)}html.dark .multiselect-btn:hover,html.dark .scale-btn:hover,html.dark .view-btn:hover{border-color:var(--primary);color:var(--primary)}html.dark .deselect-btn:hover{border-color:var(--accent);color:var(--accent)}html.dark .multiselect-btn.active,html.dark .scale-btn.active,html.dark .view-btn.active{background:var(--primary);border-color:var(--primary);color:var(--bg)}html.dark .compare-btn{background:color-mix(in srgb,var(--primary) 80%,white 20%)}html.dark .add-collection-btn{background:color-mix(in srgb,var(--gold) 80%,white 20%)}html.dark .add-planner-btn{background:color-mix(in srgb,var(--primary) 80%,white 20%)}html.dark .collection-item{color:var(--text)}html.dark .collection-item:hover{background:var(--raised);color:var(--text)}html.dark .collection-item.active{background:var(--primary);color:var(--bg)}html.dark .collection-item.active .collection-count{background:color-mix(in srgb,var(--primary) 70%,black 30%);color:var(--bg)}html.dark .cancel-delete-btn,html.dark .collection-count{background:var(--raised);color:var(--text)}html.dark .new-collection-btn{border-color:var(--border);color:var(--accent)}html.dark .sidebar-bottom-row,html.dark .sidebar-divider{border-color:var(--border)}html.dark .settings-gear-btn{color:var(--text);border-color:var(--border)}html.dark .settings-gear-btn:hover{background:var(--raised);color:var(--accent)}html.dark .dark-toggle-sidebar{color:var(--text)}html.dark .dark-toggle-sidebar:hover{background:var(--raised);color:var(--accent)}html.dark .grocery-sidebar-row{border-color:var(--border)}html.dark .grocery-sidebar-main{color:var(--text);border-color:var(--border)}html.dark .grocery-sidebar-main:hover{background:var(--raised);color:var(--text)}html.dark .grocery-sidebar-main.active{background:var(--primary);color:var(--bg)}html.dark .grocery-sidebar-regen{color:var(--text)}html.dark .collection-picker-item:hover,html.dark .grocery-sidebar-regen:hover,html.dark .multiselect-item:hover,html.dark .tag-dropdown-item:hover{background:var(--raised);color:var(--text)}.mobile-sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(30,20,30,.5);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:250;pointer-events:none}html.dark .footer{background:var(--bg)}html.dark .footer,html.dark .notes-display{border-color:var(--border)}html.dark .notes-display:hover,html.dark .recipe-tag{background:var(--raised)}html.dark .recipe-tag{color:var(--text)}html.dark .notes-section,html.dark .recipe-divider,html.dark .recipe-tag{border-color:var(--border)}html.dark .recipe-preview:after{background:linear-gradient(transparent,var(--surface))}html.dark .collection-picker-item,html.dark .grid-card-title,html.dark .grocery-item,html.dark .ingredient-item,html.dark .instruction-item,html.dark .list-title,html.dark .modal-title,html.dark .multiselect-item,html.dark .notes-text,html.dark .recipe-meta-item,html.dark .recipe-summary,html.dark .recipe-title,html.dark .tag-dropdown-item{color:var(--text)}html.dark .ingredients-label,html.dark .sidebar-label,html.dark .theme-input-label,html.dark .theme-section-title{color:var(--gold)}html.dark .settings-toggle-label{color:var(--text)}html.dark .modal-close,html.dark .theme-preset-name{color:var(--text-soft)}html.dark .modal-close:hover{color:var(--accent)}html.dark .settings-close{color:var(--text-soft)}html.dark .settings-close:hover{color:var(--accent)}html.dark .day-empty,html.dark .empty-msg,html.dark .grocery-breakdown-item,html.dark .header-subtitle,html.dark .list-source,html.dark .notes-placeholder,html.dark .planner-empty,html.dark .pool-empty{color:var(--text-muted)}html.dark .video-select-btn{border-color:var(--border);color:var(--text)}html.dark .video-delete-btn{color:var(--text-soft)}html.dark .video-delete-btn:hover{color:#ff6b6b;background:rgba(255,107,107,.1)}html.dark .auth-tabs{background:var(--raised)}html.dark .auth-tab{color:var(--text)}html.dark .auth-tab.active{background:var(--primary);color:var(--bg)}html.dark .google-auth-btn{background:color-mix(in srgb,var(--bg) 10%,white 90%);border-color:color-mix(in srgb,var(--bg) 5%,white 95%);color:#1a1a2e}html.dark .google-auth-btn:hover{background:#fff;border-color:var(--primary);color:#1a1a2e}html.dark .auth-divider{color:var(--text-muted)}html.dark .auth-divider:after,html.dark .auth-divider:before{border-color:var(--border)}html.dark .auth-field .form-label{color:var(--text)}html.dark .auth-reassurance{color:var(--text-soft)}html.dark .auth-password-hint{color:var(--text-muted)}html.dark .auth-submit-btn{background:var(--primary);color:var(--bg);font-weight:700}html.dark .auth-submit-btn:hover{background:color-mix(in srgb,var(--primary) 70%,white 30%);color:var(--bg)}html.dark .auth-submit-btn:disabled{background:color-mix(in srgb,var(--primary) 50%,var(--bg) 50%);color:var(--text-muted)}html.dark .sidebar-account-card{background:var(--raised);border-color:var(--border)}html.dark .sidebar-account-email{color:var(--text)}html.dark .sidebar-account-status{color:color-mix(in srgb,var(--accent) 70%,white 30%)}html.dark .sidebar-account-avatar{background:var(--accent);color:#fff}html.dark .sidebar-signout-btn{border-color:var(--border);color:var(--text-soft)}html.dark .sidebar-signout-btn:hover{border-color:var(--accent);color:var(--accent)}html.dark .sidebar-signin-btn{border-color:var(--accent);color:#fff;background:color-mix(in srgb,var(--accent) 15%,transparent)}html.dark .sidebar-signin-btn:hover{background:var(--accent);color:#fff}html.dark .auth-nudge-modal-text{color:var(--text-soft)}html.dark .auth-nudge-modal-signup{background:var(--accent);color:#fff}html.dark .ob-subtitle{color:var(--text-soft)}html.dark .ob-modal{background:var(--surface)}html.dark .ob-url-bar{color:var(--text)}html.dark .ob-card-mini-full,html.dark .ob-combined-item,html.dark .ob-compare-card-mini,html.dark .ob-compare-result,html.dark .ob-folder,html.dark .ob-recipe-card-chip,html.dark .ob-recipe-card-mini,html.dark .ob-recipe-stack,html.dark .ob-scroll-card-full,html.dark .ob-url-bar,html.dark .ob-view-preview{background:var(--raised);border-color:var(--border)}html.dark .ob-chip,html.dark .ob-mini-tag,html.dark .ob-raw-ingredient,html.dark .ob-tag,html.dark .ob-view-tab{background:var(--raised);color:var(--text)}html.dark .ob-view-tab.active{background:var(--primary);color:var(--bg)}html.dark .ob-line{background:var(--border)}html.dark .ob-app-layout-mini,html.dark .ob-grid-card-mini,html.dark .ob-list-row-mini,html.dark .ob-mini-day,html.dark .ob-nav,html.dark .ob-sidebar-divider{border-color:var(--border)}html.dark .ob-card-mini-title,html.dark .ob-compare-card-title,html.dark .ob-scroll-card-title,html.dark .ob-sidebar-item,html.dark .ob-stack-name{color:var(--text)}html.dark .ob-compare-result-text,html.dark .ob-scroll-card-meta,html.dark .ob-stack-ingredient{color:var(--text-soft)}html.dark .ob-sidebar-mini{background:color-mix(in srgb,var(--bg) 90%,white 10%)}html.dark .ob-save-bar-mini{background:var(--raised);border-color:var(--border)}html.dark .ob-nav-btn{border-color:var(--border);color:var(--text)}html.dark .ob-nav-btn:hover:not(:disabled){background:var(--raised)}html.dark .ob-dot-btn{background:var(--border)}html.dark .ob-dot-btn.active{background:var(--primary)}html.dark .ob-social-icon{color:var(--text-soft)}html.dark .ob-social-icon:hover{color:var(--primary)}html.dark .ob-folder,html.dark .ob-recipe-card-chip{color:var(--text)}.app-layout{display:flex;min-height:100vh;max-width:1300px;margin:0 auto;padding-top:16px}.main-content-wrapper{flex:1;display:flex;justify-content:center;min-width:0}.collections-sidebar{width:220px;flex-shrink:0;padding:40px 16px;border-right:none;background:#ede3d8;position:sticky;top:24px;height:calc(100vh - 96px);margin:0 0 24px 24px;overflow-y:auto;display:flex;flex-direction:column;gap:8px;border-radius:16px;box-shadow:0 4px 24px rgba(94,68,90,.13);transition:box-shadow .2s,transform .2s}.collections-sidebar:hover{box-shadow:0 8px 36px rgba(94,68,90,.2);transform:translateY(-2px)}.sidebar-spacer{flex:1}.sidebar-label{font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);margin-bottom:8px}.sidebar-divider{border:none;border-top:1px solid #e8d8c4;margin:8px 0}.collections-list{list-style:none;display:flex;flex-direction:column;gap:4px}.collection-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;cursor:pointer;font-size:13px;color:#6b4a5e;transition:background .15s,color .15s,transform .15s,box-shadow .15s;position:relative;list-style:none}.collection-item:hover{background:#f0e4d4;transform:scale(1.02);box-shadow:0 2px 8px rgba(94,68,90,.08)}.collection-item.active{background:var(--primary);color:white;transform:none;box-shadow:none}.collection-item.active .collection-count{background:rgba(255,255,255,.2);color:white}.collection-icon{font-size:14px;flex-shrink:0}.collection-name{flex:1;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.collection-count{font-size:10px;background:#e8d8c4;color:#6b4a5e;padding:1px 6px;border-radius:10px;font-weight:700}.collection-delete-btn{background:none;border:none;color:#c4a898;cursor:pointer;font-size:16px;padding:0 2px;line-height:1;opacity:0;transition:opacity .15s,color .15s}.collection-item:hover .collection-delete-btn{opacity:1}.collection-delete-btn:hover{color:var(--accent)}.collection-delete-confirm{display:flex;gap:4px;position:absolute;right:8px}.confirm-delete-btn{background:var(--accent);color:white}.cancel-delete-btn,.confirm-delete-btn{border:none;border-radius:4px;padding:2px 8px;font-size:11px;cursor:pointer;font-family:Lato,sans-serif}.cancel-delete-btn{background:#e8d8c4;color:#6b4a5e}.new-collection-btn{background:none;border:1.5px dashed #e0cfc0;border-radius:8px;padding:8px 10px;font-size:12px;color:#a65a6e;cursor:pointer;font-family:Lato,sans-serif;font-weight:700;transition:border-color .2s,color .2s,transform .15s,box-shadow .15s;text-align:left;margin-top:4px}.new-collection-btn:hover{border-color:var(--accent);color:var(--accent);transform:scale(1.02);box-shadow:0 2px 8px rgba(94,68,90,.1)}.new-collection-form{display:flex;flex-direction:column;gap:6px;margin-top:4px}.new-collection-input{border:1.5px solid #e0cfc0;border-radius:8px;padding:6px 10px;font-size:12px;font-family:Lato,sans-serif;color:#3a2a38;background:#fff;outline:none}.new-collection-input:focus{border-color:var(--accent)}.new-collection-save{background:var(--accent);color:white;border:none;border-radius:6px;font-weight:700}.new-collection-cancel,.new-collection-save{padding:5px 10px;font-size:11px;cursor:pointer;font-family:Lato,sans-serif}.new-collection-cancel{background:none;color:#a65a6e;border:1px solid #e0cfc0;border-radius:6px}.sidebar-bottom-row{display:flex;align-items:stretch;border-radius:8px;overflow:hidden;border:1.5px solid #e0cfc0;margin-top:4px;transition:border-color .2s}.sidebar-bottom-row:hover{border-color:var(--accent)}.settings-gear-btn{flex:3;display:flex;align-items:center;gap:8px;background:none;border:none;border-right:1.5px solid #e0cfc0;padding:8px 10px;font-size:12px;color:#6b4a5e;cursor:pointer;font-family:Lato,sans-serif;font-weight:700;transition:background .15s,color .15s}.settings-gear-btn:hover{background:#f0e4d4;color:var(--accent)}.dark-toggle-sidebar{flex:1;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#6b4a5e;padding:8px;transition:background .15s,color .15s;font-family:Lato,sans-serif}.dark-toggle-sidebar:hover{background:#f0e4d4;color:var(--accent)}.settings-gear-label{font-size:11px;letter-spacing:1px;text-transform:uppercase}.settings-overlay{display:none}.settings-sidebar{width:260px;flex-shrink:0;padding:28px 16px;background:#faf3eb;position:sticky;top:24px;height:calc(100vh - 96px);margin:0 24px 24px 0;overflow-y:auto;display:flex;flex-direction:column;gap:16px;border-radius:16px;box-shadow:0 4px 24px rgba(94,68,90,.13);animation:slideInRight .2s ease}@keyframes slideInRight{0%{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}.settings-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.settings-title{font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold)}.settings-close{background:none;border:none;font-size:16px;color:#a65a6e;cursor:pointer;padding:2px;transition:color .2s,transform .2s}.settings-close:hover{color:var(--primary);transform:scale(1.2)}.settings-body{gap:16px}.settings-body,.theme-section{display:flex;flex-direction:column}.theme-section{background:#fff;border:1.5px solid #e8d8c4;border-radius:12px;padding:14px;gap:10px}.theme-section-active{border-color:var(--primary)}.theme-section-title{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--primary);display:flex;align-items:center;gap:6px}.theme-active-badge{background:var(--primary);color:white;font-size:9px;padding:1px 6px;border-radius:10px;letter-spacing:.5px}.theme-presets{display:flex;gap:6px;flex-wrap:wrap}.theme-preset-swatch{display:flex;border-radius:6px;overflow:hidden;width:40px;height:24px;cursor:pointer;border:1.5px solid transparent;transition:border-color .15s,transform .15s;padding:0}.theme-preset-swatch:hover{border-color:var(--primary);transform:scale(1.1)}.theme-preset-swatch span{flex:1;display:block}.theme-preset-swatch.selected{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary)}.theme-preset-name{font-size:9px;font-weight:600;color:#a65a6e;letter-spacing:.5px;margin-left:auto;font-style:italic;text-transform:none}.theme-inputs{display:flex;flex-direction:column;gap:8px}.theme-input-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.theme-input-label{font-size:11px;color:#6b4a5e;font-weight:700;flex-shrink:0}.theme-input-wrapper{display:flex;align-items:center;gap:6px}.theme-color-dot{width:16px;height:16px;border-radius:50%;border:1px solid #e0cfc0;flex-shrink:0;background-color:var(--dot-color,#ccc)}.theme-hex-input{width:80px;border:1.5px solid #e0cfc0;border-radius:6px;padding:4px 8px;font-size:12px;font-family:monospace;color:#3a2a38;background:#fff;outline:none;transition:border-color .2s}.theme-hex-input:focus{border-color:var(--accent)}.settings-toggle-row{display:flex;align-items:center;justify-content:space-between}.settings-toggle-label{font-size:11px;color:#6b4a5e;font-weight:700}.settings-toggle-btn{font-size:10px;font-weight:700;letter-spacing:1px;padding:3px 10px;border-radius:20px;border:1.5px solid #e0cfc0;cursor:pointer;font-family:Lato,sans-serif;transition:all .2s}.settings-toggle-btn.on{background:var(--primary);color:white;border-color:var(--primary)}.settings-toggle-btn.off{background:none;color:#a65a6e}.main-content{width:100%;max-width:860px;padding:60px 32px 100px;min-width:0}.header{margin-bottom:24px;border-bottom:2px solid var(--primary);padding-bottom:24px}.header-eyebrow{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--accent)}.header-eyebrow,.header-title{font-weight:700;margin-bottom:8px}.header-title{font-family:Playfair Display,serif;font-size:48px;color:var(--primary);line-height:1.1}.header-subtitle{font-size:15px;color:#a65a6e;font-weight:300}.recipes-header{font-family:Playfair Display,serif;font-size:22px;color:var(--primary);margin-bottom:20px}.empty-msg{color:#a65a6e;font-size:14px;font-style:italic}.form-section{background:#fff;border:1.5px solid var(--primary);border-radius:12px;padding:28px;margin-bottom:48px;box-shadow:0 2px 16px rgba(94,68,90,.07);transition:transform .2s,box-shadow .2s}.form-section:hover{transform:scale(1.01) rotate(.3deg);box-shadow:0 8px 32px rgba(94,68,90,.13)}.form-label{display:block;font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--primary);margin-bottom:10px}.form-row{display:flex;gap:12px}.form-input{flex:1;border:1.5px solid #e0cfc0;border-radius:8px;padding:12px 16px;font-size:14px;font-family:Lato,sans-serif;color:#3a2a38;background:var(--bg);outline:none;transition:border-color .2s}.form-input:focus{border-color:var(--accent)}.form-input::placeholder{color:#c4a898}.submit-btn{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:12px 24px;font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;cursor:pointer;font-family:Lato,sans-serif;transition:background .2s,transform .2s,box-shadow .2s;white-space:nowrap}.submit-btn:hover{background:#c45e30;transform:scale(1.04) rotate(-.5deg);box-shadow:0 4px 16px rgba(220,114,67,.3)}html.dark .submit-btn{background:var(--accent);box-shadow:0 4px 16px color-mix(in srgb,var(--accent) 30%,transparent)}html.dark .submit-btn:hover{background:color-mix(in srgb,var(--accent) 70%,white 30%);box-shadow:0 4px 16px color-mix(in srgb,var(--accent) 40%,transparent)}.submit-btn:disabled{background:#e0b89e;cursor:not-allowed;transform:none}.error-msg{margin-top:12px;font-size:13px;color:#c0392b}.sticky-actions{position:sticky;top:16px;z-index:50;display:flex;gap:10px;margin-bottom:24px;flex-wrap:wrap;align-items:center}.compare-btn{background:#a65a6e;color:white;border:3px solid rgba(255,255,255,.9);border-radius:12px;padding:10px 20px;font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;cursor:pointer;font-family:Lato,sans-serif;transition:background .2s,transform .2s,box-shadow .2s;box-shadow:0 4px 20px rgba(0,0,0,.2);white-space:nowrap}.compare-btn:hover{background:#8a4a5a;transform:scale(1.04) rotate(-.5deg)}.add-collection-btn{background:var(--gold);color:white;border:3px solid rgba(255,255,255,.9);border-radius:12px;padding:10px 20px;font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;cursor:pointer;font-family:Lato,sans-serif;transition:background .2s,transform .2s,box-shadow .2s;box-shadow:0 4px 20px rgba(0,0,0,.2);white-space:nowrap}.add-collection-btn:hover{background:#c4843a;transform:scale(1.04) rotate(-.5deg)}.add-planner-btn{background:var(--primary);color:white;border:3px solid rgba(255,255,255,.9);border-radius:12px;padding:10px 20px;font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;cursor:pointer;font-family:Lato,sans-serif;transition:background .2s,transform .2s,box-shadow .2s;box-shadow:0 4px 20px rgba(0,0,0,.2);white-space:nowrap}.add-planner-btn:hover{background:#3a2a38;transform:scale(1.04) rotate(-.5deg)}.deselect-btn{background:#f5ede3;border:1.5px solid #e0cfc0;border-radius:12px;padding:10px 16px;font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#a65a6e;cursor:pointer;font-family:Lato,sans-serif;transition:all .2s;white-space:nowrap;box-shadow:0 4px 20px rgba(0,0,0,.1)}.deselect-btn:hover{background:#fde8e0;border-color:var(--accent);color:var(--accent)}.collection-picker-wrapper{position:relative}.collection-picker{position:absolute;top:calc(100% + 8px);left:0;background:#fff;border:1.5px solid #e0cfc0;border-radius:12px;box-shadow:0 4px 20px rgba(94,68,90,.15);z-index:100;min-width:200px;overflow:hidden;padding:6px 0}.collection-picker-item{display:block;width:100%;text-align:left;background:none;border:none;padding:10px 16px;font-size:13px;font-family:Lato,sans-serif;color:#3a2a38;cursor:pointer;transition:background .15s}.collection-picker-item:hover{background:var(--bg);color:var(--accent)}.collection-picker-new{padding:8px 12px;border-top:1px solid #f0e0d0}.collection-picker-input{width:100%;border:1.5px solid #e0cfc0;border-radius:8px;padding:6px 10px;font-size:12px;font-family:Lato,sans-serif;color:#3a2a38;background:var(--bg);outline:none}.collection-picker-input:focus{border-color:var(--accent)}.collection-picker-input::placeholder{color:#c4a898}.recipe-list{display:flex;flex-direction:column}.search-row{display:flex;gap:12px;margin-bottom:16px;align-items:center}.search-input{flex:1;border:1.5px solid #e0cfc0;border-radius:8px;padding:10px 16px;font-size:14px;font-family:Lato,sans-serif;color:#3a2a38;background:#fff;outline:none;transition:border-color .2s,box-shadow .2s,transform .2s}.search-input:focus{border-color:var(--accent)}.search-input:hover{box-shadow:0 2px 8px rgba(94,68,90,.1);transform:scale(1.005)}.search-input::placeholder{color:#c4a898}.sort-select{border:1.5px solid #e0cfc0;border-radius:8px;padding:10px 40px 10px 16px;font-size:14px;font-family:Lato,sans-serif;color:#3a2a38;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%235e445a' d='M6 8L1 3h10z'/%3E%3C/svg%3E") no-repeat right 14px center;appearance:none;outline:none;cursor:pointer;transition:border-color .2s,transform .2s}.sort-select:focus{border-color:var(--accent)}.sort-select:hover{transform:scale(1.03) rotate(-.5deg)}.filter-row{display:flex;gap:8px;margin-bottom:24px;align-items:center;flex-wrap:wrap}.view-selector{margin-left:auto;display:flex;gap:4px}.view-btn{background:#fff;border:1.5px solid #e0cfc0;border-radius:8px;padding:7px 10px;cursor:pointer;color:#6b4a5e;transition:all .15s;display:flex;align-items:center;justify-content:center}.view-btn:hover{border-color:var(--primary);color:var(--primary)}.view-btn.active{background:var(--primary);border-color:var(--primary);color:white}.multiselect-wrapper{position:relative}.multiselect-btn{background:#fff;border:1.5px solid #e0cfc0;border-radius:8px;padding:8px 14px;font-size:12px;font-weight:700;letter-spacing:.5px;color:#6b4a5e;cursor:pointer;font-family:Lato,sans-serif;transition:all .2s;white-space:nowrap}.multiselect-btn:hover{border-color:var(--primary);color:var(--primary);transform:scale(1.03)}.multiselect-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.multiselect-dropdown{position:absolute;top:calc(100% + 4px);left:0;background:#fff;border:1.5px solid #e0cfc0;border-radius:10px;box-shadow:0 4px 20px rgba(94,68,90,.12);z-index:200;min-width:180px;max-height:240px;overflow-y:auto;padding:6px 0}.multiselect-item{display:flex;align-items:center;gap:8px;padding:8px 14px;font-size:13px;font-family:Lato,sans-serif;color:#3a2a38;cursor:pointer;transition:background .15s}.multiselect-item:hover{background:var(--bg)}.multiselect-item input{accent-color:var(--primary);cursor:pointer}.multiselect-empty{padding:10px 14px;font-size:13px;color:#c4a898;font-style:italic}.clear-filters-btn{background:none;border:none;color:#a65a6e;font-size:12px;font-family:Lato,sans-serif;cursor:pointer;padding:4px 8px;text-decoration:underline;transition:color .2s}.clear-filters-btn:hover{color:var(--accent)}.recipe-card{background:#fff;border:1.5px solid #e8d8c4;border-radius:12px;padding:24px 28px;margin-bottom:20px;box-shadow:0 2px 12px rgba(94,68,90,.06);transition:transform .2s,box-shadow .2s;position:relative}.recipe-card:hover{transform:scale(1.01);box-shadow:0 8px 28px rgba(94,68,90,.13)}.recipe-card.selected{box-shadow:0 20px 60px rgba(94,68,90,.25),0 8px 24px rgba(94,68,90,.15);transform:scale(1.04);z-index:10}.recipe-image-wrapper{position:relative;margin-bottom:16px;border-radius:8px;overflow:hidden;cursor:pointer;height:180px;transform:translateZ(0)}.recipe-image-bg{position:absolute;inset:-10px;background-size:cover;background-position:50%;filter:blur(12px) brightness(.85);transform:scale(1.1);transition:transform .4s ease;z-index:0}.recipe-image{position:relative;width:100%;height:180px;object-fit:contain;display:block;z-index:1;transition:transform .4s ease}.source-badge{position:absolute;top:10px;left:10px;background:rgba(94,68,90,.85);color:#fff;font-size:10px;font-weight:700;letter-spacing:.5px;padding:4px 10px;border-radius:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:3;pointer-events:none}.recipe-image-overlay{position:absolute;inset:0;background:rgba(94,68,90,0);display:flex;align-items:center;justify-content:center;transition:background .3s;border-radius:8px;z-index:2}.overlay-checked{background:rgba(94,68,90,.25)!important}.overlay-icons{display:flex;gap:20px;align-items:center}.overlay-checkmark,.overlay-trash{width:48px;height:48px;opacity:0;transform:scale(.8);transition:opacity .2s,transform .2s;filter:drop-shadow(0 2px 8px rgba(0,0,0,.3))}.overlay-checked .overlay-checkmark{opacity:1;transform:scale(1)}.overlay-trash-btn{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center}.mobile-image-actions{display:none}.no-image-actions{display:flex;justify-content:flex-end;margin-bottom:8px}.no-image-trash-btn{background:none;border:none;cursor:pointer;padding:4px;opacity:.4;transition:opacity .2s,transform .2s}.no-image-trash-btn:hover{opacity:1;transform:scale(1.15)}@media (hover:hover){.recipe-image-wrapper:hover .recipe-image-overlay{background:rgba(94,68,90,.45)}.recipe-image-wrapper:hover .overlay-checked{background:rgba(94,68,90,.55)!important}.recipe-image-wrapper:hover .recipe-image-bg{transform:scale(1.25)}.recipe-image-wrapper:hover .recipe-image{transform:scale(1.05)}.recipe-image-wrapper:hover .overlay-checkmark,.recipe-image-wrapper:hover .overlay-trash{opacity:1;transform:scale(1)}.overlay-trash-btn:hover .overlay-trash{transform:scale(1.2)!important}.grid-card-image-wrapper:hover .overlay-checkmark,.grid-card-image-wrapper:hover .overlay-trash{opacity:1;transform:scale(1)}}.recipe-meta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px}.recipe-meta-item{display:flex;align-items:center;gap:4px;font-size:12px;color:#6b4a5e}.recipe-meta-icon{font-size:13px}.recipe-meta-label{font-weight:700;font-size:10px;letter-spacing:.5px;text-transform:uppercase;color:var(--gold);margin-right:2px}.recipe-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px;align-items:center}.recipe-tag{background:#f5ede3;border:1px solid #e0cfc0;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700;letter-spacing:.5px;color:#a65a6e;cursor:pointer;font-family:Lato,sans-serif;transition:all .15s}.recipe-tag:hover{background:#fde8e0;border-color:var(--accent);color:var(--accent)}.tag-input-wrapper{position:relative;display:flex;align-items:center}.tag-input{border:1.5px dashed #e0cfc0;border-radius:20px;padding:3px 28px 3px 10px;font-size:11px;font-family:Lato,sans-serif;color:#3a2a38;background:transparent;outline:none;width:110px;transition:border-color .2s}.tag-input:focus{border-color:var(--accent)}.tag-input::placeholder{color:#c4a898}.tag-add-btn{position:absolute;right:6px;background:#4e6646;color:white;border:none;border-radius:50%;width:16px;height:16px;font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .2s,transform .2s}.tag-add-btn:hover{background:#3a4e32;transform:scale(1.15)}.tag-dropdown{position:absolute;top:calc(100% + 4px);left:0;background:#fff;border:1.5px solid #e0cfc0;border-radius:10px;box-shadow:0 4px 16px rgba(94,68,90,.12);z-index:200;min-width:150px;overflow:hidden}.tag-dropdown-item{display:block;width:100%;text-align:left;background:none;border:none;padding:8px 14px;font-size:12px;font-family:Lato,sans-serif;color:#3a2a38;cursor:pointer;transition:background .15s}.tag-dropdown-item:hover{background:var(--bg);color:var(--accent)}.recipe-card-header{display:flex;align-items:flex-start}.recipe-title{font-family:Playfair Display,serif;font-size:20px;color:var(--primary);text-decoration:none;display:inline-flex;align-items:baseline;gap:6px;line-height:1.3;flex:1;transition:color .2s}.recipe-title:hover{color:var(--accent)}.recipe-title-arrow{font-size:13px;opacity:0;transform:translateX(-4px);transition:opacity .2s,transform .2s;flex-shrink:0}.recipe-title:hover .recipe-title-arrow{opacity:1;transform:translateX(0)}.recipe-divider{border:none;border-top:1px solid #f0e0d0;margin:16px 0}.recipe-details{margin-top:4px;position:relative}.recipe-preview{max-height:80px;overflow:hidden;position:relative;pointer-events:none}.recipe-preview:after{content:"";position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(transparent,#fff)}.recipe-summary{font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);cursor:pointer;margin-top:8px;display:inline-block;background:none;border:none;padding:0;font-family:Lato,sans-serif;transition:color .2s,transform .2s}.recipe-summary:hover{color:#c45e30;transform:scale(1.04) rotate(-.5deg)}.scale-controls{display:flex;gap:6px;margin:12px 0 8px}.scale-btn{background:#fff;border:1.5px solid #e0cfc0;border-radius:20px;padding:4px 14px;font-size:13px;font-weight:700;color:#6b4a5e;cursor:pointer;font-family:Lato,sans-serif;transition:all .15s}.scale-btn:hover{border-color:var(--primary);color:var(--primary)}.scale-btn.active{background:var(--primary);border-color:var(--primary);color:white}.scale-btn-half{font-size:15px}.recipe-columns{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:12px}.ingredients-label{font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);margin-bottom:10px}.ingredients-list{list-style:none;display:flex;flex-direction:column;gap:6px}.ingredient-item{font-size:14px;color:#6b4a5e;padding-left:16px;position:relative;line-height:1.5}.ingredient-item:before{content:"—";position:absolute;left:0;color:var(--gold);font-size:12px}.instructions-list{list-style:none;display:flex;flex-direction:column;gap:8px;counter-reset:steps}.instruction-item{font-size:14px;color:#6b4a5e;padding-left:28px;position:relative;line-height:1.6;counter-increment:steps}.instruction-item:before{content:counter(steps);position:absolute;left:0;top:1px;background:var(--primary);color:white;width:18px;height:18px;border-radius:50%;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}.notes-section{margin-top:20px;padding-top:16px;border-top:1px solid #f0e0d0}.notes-display{cursor:pointer;padding:10px 14px;border-radius:8px;border:1.5px dashed #e0cfc0;transition:border-color .2s,background .2s;min-height:42px}.notes-display:hover{border-color:var(--accent);background:var(--bg)}.notes-text{font-size:14px;color:#6b4a5e;line-height:1.6}.notes-placeholder{font-size:14px;color:#c4a898;font-style:italic}.notes-textarea{width:100%;border:1.5px solid #e0cfc0;border-radius:8px;padding:10px 14px;font-size:14px;font-family:Lato,sans-serif;color:#3a2a38;background:var(--bg);outline:none;resize:vertical;transition:border-color .2s;line-height:1.6}.notes-textarea:focus{border-color:var(--accent)}.notes-actions{display:flex;gap:8px;margin-top:8px}.notes-save-btn{background:var(--accent);color:white;border:none;border-radius:8px;padding:8px 16px;font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;cursor:pointer;font-family:Lato,sans-serif;transition:background .2s,transform .2s}.notes-save-btn:hover{background:#c45e30;transform:scale(1.03)}.notes-save-btn:disabled{background:#e0b89e;cursor:not-allowed;transform:none}.notes-cancel-btn{background:none;color:#a65a6e;border:1.5px solid #e0cfc0;border-radius:8px;padding:8px 16px;font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;cursor:pointer;font-family:Lato,sans-serif;transition:border-color .2s}.notes-cancel-btn:hover{border-color:#a65a6e}.list-view{display:flex;flex-direction:column;gap:8px}.list-row{display:flex;align-items:center;gap:12px;background:#fff;border:1.5px solid #e8d8c4;border-radius:10px;padding:10px 14px;transition:box-shadow .15s,transform .15s}.list-row:hover{box-shadow:0 4px 16px rgba(94,68,90,.1);transform:scale(1.005)}.list-row.selected{border-color:var(--primary)}.list-checkbox{accent-color:var(--primary);cursor:pointer;flex-shrink:0;width:16px;height:16px}.list-thumb{object-fit:cover}.list-thumb,.list-thumb-placeholder{width:40px;height:40px;border-radius:6px;flex-shrink:0}.list-thumb-placeholder{background:#f0e4d4}.list-title{font-family:Playfair Display,serif;font-size:15px;color:var(--primary);text-decoration:none;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-title:hover{color:var(--accent)}.list-tags{display:flex;gap:4px;flex-shrink:0}.list-source{font-size:11px;color:#a65a6e;flex-shrink:0;white-space:nowrap}.list-expand-btn{background:none;border:1.5px solid #e0cfc0;border-radius:6px;padding:5px 8px;cursor:pointer;color:#6b4a5e;transition:all .15s;flex-shrink:0;display:flex;align-items:center}.list-expand-btn:hover{border-color:var(--primary);color:var(--primary)}.list-delete-btn{background:none;border:none;cursor:pointer;color:#c4a898;padding:4px;transition:color .15s,transform .15s;flex-shrink:0;display:flex;align-items:center}.list-delete-btn:hover{color:#ff6b6b;transform:scale(1.15)}.grid-view{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.grid-card{background:#fff;border:1.5px solid #e8d8c4;border-radius:12px;overflow:hidden;transition:transform .2s,box-shadow .2s}.grid-card:hover{transform:scale(1.02);box-shadow:0 8px 24px rgba(94,68,90,.13)}.grid-card.selected{border-color:var(--primary);box-shadow:0 8px 24px rgba(94,68,90,.2)}.grid-card-image-wrapper{position:relative;height:140px;cursor:pointer;overflow:hidden}.grid-card-image{position:relative;width:100%;height:140px;object-fit:cover;display:block;z-index:1;transition:transform .3s}.grid-card-image-wrapper:hover .grid-card-image{transform:scale(1.05)}.grid-card-no-image{width:100%;height:140px;background:#f0e4d4}.grid-card-overlay{position:absolute;inset:0;background:rgba(94,68,90,0);display:flex;align-items:center;justify-content:center;transition:background .3s;z-index:2}.grid-card-image-wrapper:hover .grid-card-overlay{background:rgba(94,68,90,.45)}.grid-card-body{padding:12px}.grid-card-title{font-family:Playfair Display,serif;font-size:14px;color:var(--primary);line-height:1.3;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-clamp:2;overflow:hidden}.grid-show-more{background:none;border:1.5px solid #e0cfc0;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:700;color:#6b4a5e;cursor:pointer;font-family:Lato,sans-serif;transition:all .15s}.grid-show-more:hover{border-color:var(--primary);color:var(--primary)}.grid-card-mobile-actions{display:none}.recipe-detail-modal{max-width:700px}.recipe-detail-modal .modal-body{padding:16px}.recipe-detail-modal .recipe-card{margin-bottom:0;box-shadow:none;border:none;transform:none!important}.video-wrapper{margin-bottom:16px}.video-thumbnail-wrapper{position:relative;width:100%;padding-top:56.25%;border-radius:8px;overflow:hidden;cursor:pointer;background:#000}.video-thumbnail{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:opacity .2s}.video-thumbnail-wrapper:hover .video-thumbnail{opacity:.85}.video-play-btn{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:2}.video-iframe{width:100%;aspect-ratio:16/9;border:none;border-radius:8px;display:block}.video-actions{display:flex;gap:8px;margin-top:8px;align-items:center}.video-select-btn{background:none;border:1.5px solid #e0cfc0;border-radius:20px;padding:4px 14px;font-size:12px;font-weight:700;color:#6b4a5e;cursor:pointer;font-family:Lato,sans-serif;transition:all .15s}.video-select-btn:hover{border-color:var(--primary);color:var(--primary)}.video-select-btn.active{background:var(--primary);border-color:var(--primary);color:white}.video-delete-btn{background:none;border:none;cursor:pointer;color:#c4a898;font-size:12px;font-weight:700;font-family:Lato,sans-serif;display:flex;align-items:center;gap:4px;padding:4px 8px;border-radius:6px;transition:color .15s,background .15s}.video-delete-btn:hover{color:#ff6b6b;background:#fde8e0}.grocery-sidebar-widget{display:flex;flex-direction:column;border-radius:8px;overflow:visible;position:relative}.grocery-sidebar-row{border-radius:8px;display:flex;align-items:stretch;border:1.5px solid #e0cfc0;border-radius:8px 8px 0 0;overflow:hidden;transition:border-color .2s}.grocery-sidebar-main{flex:3;display:flex;align-items:center;gap:8px;background:none;border:none;border-right:1.5px solid #e0cfc0;padding:8px 10px;font-size:13px;font-weight:600;color:#6b4a5e;cursor:pointer;font-family:Lato,sans-serif;transition:background .15s,color .15s;text-align:left}.grocery-sidebar-main:hover{background:#f0e4d4;color:var(--accent)}.grocery-sidebar-main.active{background:var(--primary);color:white;border-color:var(--primary)}.grocery-sidebar-main.active+.grocery-sidebar-regen{border-color:var(--primary)}.grocery-sidebar-regen{flex:1;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#6b4a5e;padding:8px;transition:background .15s,color .15s}.grocery-sidebar-regen:hover{background:#f0e4d4;color:var(--accent)}.grocery-source-chevron{display:flex;align-items:center;justify-content:center;width:100%;background:var(--accent);padding:3px 0;cursor:pointer;color:white;opacity:.85;transition:opacity .15s;border:1.5px solid rgba(255,255,255,.2);border-top:none;border-radius:0 0 6px 6px;position:relative;z-index:1}.grocery-source-chevron:hover{opacity:1}.grocery-source-chevron svg{transition:transform .25s ease}.grocery-source-chevron.open svg{transform:rotate(180deg)}.grocery-source-dropdown{background:var(--accent);overflow:hidden;max-height:0;transition:max-height .25s ease;border-radius:0;margin-top:0}.grocery-source-dropdown.open{max-height:120px}.grocery-source-label{font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.7);padding:8px 12px 4px}.grocery-source-option{display:block;width:100%;text-align:left;background:none;padding:8px 12px;font-size:12px;font-weight:600;color:white;cursor:pointer;font-family:Lato,sans-serif;transition:background .15s;border:none;border-top:1px solid rgba(255,255,255,.15)}.grocery-source-option:hover{background:rgba(255,255,255,.15)}.grocery-source-option.selected{background:rgba(255,255,255,.2)}.grocery-source-option.selected:before{content:"✓ ";font-size:11px}.pool-empty{font-size:12px;color:#c4a898;font-style:italic;padding:4px 0}.grocery-panel{position:fixed;bottom:48px;right:24px;width:340px;background:#fff;border:1.5px solid var(--primary);border-bottom:none;border-radius:12px 12px 0 0;box-shadow:0 -4px 24px rgba(94,68,90,.15);z-index:100;max-height:60vh;display:flex;flex-direction:column}.grocery-minimized{max-height:none}.grocery-panel-hidden{display:none!important}.grocery-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--primary);color:white;border-radius:10px 10px 0 0;font-size:14px;font-weight:700;font-family:Lato,sans-serif;gap:8px}.grocery-minimize-btn{background:none;border:none;color:rgba(255,255,255,.7);cursor:pointer;font-size:12px;padding:0;transition:color .2s}.grocery-minimize-btn:hover{color:white}.grocery-close-btn{background:none;border:none;color:rgba(255,255,255,.7);cursor:pointer;font-size:14px;padding:0 0 0 4px;transition:color .2s}.grocery-close-btn:hover{color:white}.grocery-panel-body{overflow-y:auto;padding:16px 18px;flex:1}.grocery-list{list-style:none;display:flex;flex-direction:column;gap:10px}.grocery-item{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:#3a2a38;line-height:1.4}.grocery-item input[type=checkbox]{margin-top:2px;accent-color:var(--accent);flex-shrink:0}.grocery-checked{text-decoration:line-through;color:#b0a0a8}.grocery-breakdown{list-style:none;margin-top:4px;padding-left:4px;display:flex;flex-direction:column;gap:2px}.grocery-breakdown-item{font-size:11px;color:#a65a6e;padding-left:10px;position:relative;line-height:1.4}.grocery-breakdown-item:before{content:"·";position:absolute;left:0;color:var(--gold)}.grocery-regenerate-btn{background:none;border:1.5px solid #e0cfc0;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:700;color:#6b4a5e;cursor:pointer;font-family:Lato,sans-serif;transition:all .15s;margin-bottom:12px;display:block}.grocery-regenerate-btn:hover{border-color:var(--primary);color:var(--primary)}.grocery-regenerate-btn:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:rgba(58,42,56,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:300;display:flex;align-items:center;justify-content:center;padding:24px}.modal{background:var(--bg);border-radius:16px;width:100%;max-width:900px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 24px 80px rgba(58,42,56,.3)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 28px;border-bottom:1.5px solid #e8d8c4}.modal-title{font-family:Playfair Display,serif;font-size:22px;color:var(--primary)}.modal-close{background:none;border:none;font-size:18px;color:#a65a6e;cursor:pointer;padding:4px;transition:color .2s,transform .2s}.modal-close:hover{color:var(--primary);transform:scale(1.2)}.modal-body{overflow-y:auto;padding:24px 28px;display:flex;flex-direction:column;gap:24px}.compare-cards-grid{display:grid;gap:16px}.compare-cards-grid:has(>:nth-child(2):last-child){grid-template-columns:1fr 1fr}.compare-cards-grid:has(>:nth-child(3):last-child){grid-template-columns:1fr 1fr 1fr}.compare-cards-grid:has(>:nth-child(4):last-child){grid-template-columns:1fr 1fr}.compare-card{background:#fff;border:1.5px solid #e8d8c4;border-radius:12px;padding:16px}.compare-card-image-wrapper{position:relative;height:120px;border-radius:8px;overflow:hidden;margin-bottom:12px}.compare-card-image{width:100%;height:120px;object-fit:contain;display:block}.compare-card-title{font-family:Playfair Display,serif;font-size:15px;color:var(--primary);text-decoration:none;display:block;line-height:1.3;margin-bottom:8px}.compare-card-title:hover{color:var(--accent)}.comparison-box{background:#fff;border:1.5px solid #e8d8c4;border-radius:12px;padding:20px}.comparison-loading{font-size:14px;color:#a65a6e;font-style:italic}.comparison-error{font-size:14px;color:#c0392b}.comparison-text{font-size:14px;color:#6b4a5e;line-height:1.7}.meal-planner{display:flex;flex-direction:column;gap:24px}.planner-header{display:flex;align-items:center;justify-content:space-between}.planner-actions{display:flex;gap:12px;align-items:center}.clear-planner-btn{background:none;border:1.5px solid #e0cfc0;border-radius:8px;padding:8px 16px;font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#a65a6e;cursor:pointer;font-family:Lato,sans-serif;transition:all .2s}.clear-planner-btn:hover{border-color:var(--accent);color:var(--accent)}.planner-grocery-btn{background:#4e6646;color:white;border:none;border-radius:8px;padding:8px 16px;font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;cursor:pointer;font-family:Lato,sans-serif;transition:background .2s,transform .2s}.planner-grocery-btn:hover{background:#3a4e32;transform:scale(1.02)}.unscheduled-pool{background:#fff;border:2px dashed #e0cfc0;border-radius:12px;padding:16px;transition:border-color .2s,background .2s}.unscheduled-pool.drag-over{border-color:var(--gold);background:var(--bg)}.pool-label{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:12px}.pool-recipes{display:flex;flex-wrap:wrap;gap:8px}.planner-empty{text-align:center;padding:48px 24px;color:#a65a6e}.planner-empty p{margin-bottom:8px;font-size:14px;line-height:1.6}.planner-empty strong{color:var(--primary)}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:12px}.day-column{background:#fff;border:1.5px solid #e8d8c4;border-radius:12px;padding:12px;min-height:160px;transition:border-color .2s,background .2s;display:flex;flex-direction:column}.day-column.drag-over{border-color:var(--primary);background:#f5ede3}.day-label{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--primary);margin-bottom:10px}.day-recipes{display:flex;flex-direction:column;gap:8px;flex:1}.day-empty{font-size:12px;color:#c4a898;font-style:italic;text-align:center;margin-top:12px}.planner-recipe-chip{display:flex;align-items:center;gap:6px;background:var(--bg);border:1px solid #e0cfc0;border-radius:8px;padding:6px 8px;cursor:grab;transition:all .15s}.planner-recipe-chip:hover{border-color:var(--primary);box-shadow:0 2px 8px rgba(94,68,90,.12)}.planner-recipe-chip.dragging{opacity:.4;transform:scale(.95)}.chip-image{width:28px;height:28px;object-fit:cover;border-radius:4px;flex-shrink:0}.chip-title{font-size:11px;color:var(--primary);font-weight:600;flex:1;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-clamp:2;line-height:1.3}.chip-remove{background:none;border:none;color:#c4a898;cursor:pointer;font-size:14px;padding:0;line-height:1;flex-shrink:0;transition:color .15s}.chip-remove:hover{color:var(--accent)}.ob-overlay{position:fixed;inset:0;background:rgba(30,20,30,.6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px}.ob-modal{background:var(--bg);border-radius:24px;width:100%;max-width:560px;min-height:520px;max-height:85vh;box-shadow:0 32px 80px rgba(0,0,0,.35);display:flex;flex-direction:column;padding:40px 40px 28px;position:relative;overflow:hidden}.ob-skip{position:absolute;top:16px;right:20px;background:none;border:none;font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#a65a6e;cursor:pointer;font-family:Lato,sans-serif;opacity:.7;transition:opacity .2s}.ob-skip:hover{opacity:1}.ob-slide{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;transition:opacity .2s ease,transform .2s ease}.ob-enter{opacity:1;transform:translateX(0)}.ob-exit-left{opacity:0;transform:translateX(-20px)}.ob-exit-right{opacity:0;transform:translateX(20px)}.ob-emoji{font-size:48px;margin-bottom:16px}.ob-title{font-family:Playfair Display,serif;font-size:26px;font-weight:700;color:var(--primary);margin-bottom:12px;line-height:1.2}.ob-subtitle{font-size:14px;color:#6b4a5e;line-height:1.7;max-width:420px;margin-bottom:24px}.ob-animation-container{flex:1;justify-content:center;min-height:180px}.ob-animation,.ob-animation-container{width:100%;display:flex;align-items:center}.ob-animation{flex-direction:column;gap:10px;position:relative}.ob-url-animation{min-height:200px;justify-content:center}.ob-url-bar{display:flex;align-items:center;gap:10px;background:#fff;border:1.5px solid #e0cfc0;border-radius:8px;padding:10px 14px;width:100%;max-width:360px;font-size:12px;color:#3a2a38;transition:border-color .3s}.ob-url-bar.ob-typing{border-color:var(--accent)}.ob-url-icon{font-size:14px;flex-shrink:0}.ob-url-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ob-url-check{color:#4e6646;font-weight:700}.ob-typewriter{display:inline-block;overflow:hidden;white-space:nowrap;animation:typewriter .8s steps(40) forwards;max-width:100%}@keyframes typewriter{0%{width:0}to{width:100%}}.ob-arrow-down{font-size:20px;color:var(--gold);opacity:0;transition:opacity .3s}.ob-arrow-down.ob-visible{opacity:1}.ob-recipe-card-mini{gap:12px;padding:12px;max-width:360px;transform:scale(.8) translateY(10px)}.ob-card-image{width:60px;height:60px;border-radius:8px;background:linear-gradient(135deg,#e8d8c4,#dc7243);flex-shrink:0}.ob-card-content{flex:1;text-align:left}.ob-card-title{font-family:Playfair Display,serif;font-size:14px;color:var(--primary);font-weight:700;margin-bottom:6px}.ob-card-tags{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:6px}.ob-tag{background:#f5ede3;border-radius:20px;padding:2px 8px;font-weight:700}.ob-card-meta,.ob-tag{font-size:10px;color:#a65a6e}.ob-particle{position:absolute;width:6px;height:6px;border-radius:50%;animation:particleBurst .6s ease-out forwards;--angle:0deg}@keyframes particleBurst{0%{transform:translate(0) scale(1);opacity:1}to{transform:translate(calc(cos(var(--angle)) * 60px),calc(sin(var(--angle)) * 60px)) scale(0);opacity:0}}.ob-views-animation{gap:12px}.ob-view-tabs{display:flex;gap:6px}.ob-view-tab{padding:4px 12px;border-radius:6px;font-size:12px;font-weight:700;background:#f5ede3;color:#a65a6e;font-family:Lato,sans-serif;transition:all .3s}.ob-view-tab.active{background:var(--primary);color:white}.ob-view-preview{width:100%;max-width:360px;background:#fff;border:1.5px solid #e8d8c4;border-radius:10px;padding:12px;min-height:120px}.ob-scroll-preview{display:flex;flex-direction:column;gap:8px}.ob-scroll-card{display:flex;gap:10px;align-items:center}.ob-mini-image{width:40px;height:40px;border-radius:6px;background:linear-gradient(135deg,#e8d8c4,#dc7243);flex-shrink:0}.ob-mini-lines{flex:1;display:flex;flex-direction:column;gap:5px}.ob-line{height:6px;border-radius:3px;background:#e8d8c4}.ob-line-title{width:80%}.ob-line-short{width:60%}.ob-line-shorter{width:40%}.ob-list-preview{display:flex;flex-direction:column;gap:6px}.ob-list-row-mini{display:flex;align-items:center;gap:8px;padding:4px 0;border-bottom:1px solid #f0e4d4}.ob-mini-thumb{width:24px;height:24px;border-radius:4px;background:linear-gradient(135deg,#e8d8c4,#dc7243);flex-shrink:0}.ob-mini-tag{width:32px;height:14px;border-radius:10px;background:#f5ede3}.ob-grid-preview{display:grid;grid-template-columns:1fr 1fr;gap:8px}.ob-grid-card-mini{border:1px solid #e8d8c4;border-radius:8px;overflow:hidden}.ob-mini-image-sq{width:100%;height:48px;background:linear-gradient(135deg,#e8d8c4,#dc7243)}.ob-collections-animation{min-height:120px}.ob-collections-layout{display:flex;align-items:center;gap:16px;width:100%;justify-content:center}.ob-recipe-chips{display:flex;flex-direction:column;gap:6px}.ob-chip{background:#f5ede3;border:1.5px solid #e0cfc0;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:700;color:#a65a6e;font-family:Lato,sans-serif;transition:all .3s}.ob-chip-done{opacity:.4}.ob-arrow-right{font-size:20px;color:var(--gold)}.ob-collection-folders{display:flex;flex-direction:column;gap:8px}.ob-folder{display:flex;align-items:center;gap:6px;background:#fff;border:1.5px solid #e8d8c4;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:700;color:var(--primary);font-family:Lato,sans-serif}.ob-folder-count{background:var(--primary);color:white;border-radius:10px;padding:1px 6px;font-size:10px}.ob-planner-animation{gap:8px}.ob-mini-week{display:flex;gap:6px;width:100%;justify-content:center}.ob-mini-day{flex:1;border:1px solid #e8d8c4;border-radius:8px;padding:6px;min-height:80px}.ob-mini-day-label{font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--primary);margin-bottom:4px;text-align:center}.ob-mini-day-body{display:flex;flex-direction:column;gap:3px}.ob-mini-chip{border-radius:6px;padding:3px 6px;font-size:9px;font-weight:700;color:white;font-family:Lato,sans-serif;animation:chipDrop .3s ease;text-align:center}@keyframes chipDrop{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.ob-chip-waiting{background:none!important;border:1.5px solid}.ob-unscheduled-mini{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}.ob-grocery-animation{min-height:160px;gap:8px}.ob-ingredient-cloud{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;opacity:0;transition:opacity .4s;max-width:360px}.ob-ingredient-cloud.ob-visible{opacity:1}.ob-raw-ingredient{background:#f5ede3;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600;color:#a65a6e;font-family:Lato,sans-serif;transition:all .3s}.ob-raw-ingredient.ob-merging{opacity:0;transform:scale(.5)}.ob-combined-list{display:flex;flex-direction:column;gap:6px;width:100%;max-width:260px}.ob-combined-item{background:#fff;border:1.5px solid #e8d8c4;border-radius:8px;padding:8px 12px;font-size:12px;font-weight:600;color:var(--primary);font-family:Lato,sans-serif;animation:slideIn .3s ease forwards;opacity:0}@keyframes slideIn{0%{opacity:0;transform:translateX(-12px)}to{opacity:1;transform:translateX(0)}}.ob-combined-check{color:#4e6646;margin-right:4px}.ob-theme-animation{align-items:center}.ob-theme-preview{border:2px solid;border-radius:12px;padding:16px;width:100%;max-width:280px}.ob-theme-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:10px;border-bottom:1px solid;margin-bottom:10px}.ob-theme-title{font-family:Playfair Display,serif;font-size:16px;font-weight:700;transition:color .6s}.ob-theme-dots{display:flex;gap:6px}.ob-dot{width:10px;height:10px;border-radius:50%;transition:background .6s}.ob-theme-card{border:1px solid;border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:6px;transition:all .6s}.ob-theme-bar{height:8px;border-radius:4px;width:60%;transition:background .6s}.ob-theme-line{height:6px;border-radius:3px;width:90%;transition:background .6s}.ob-theme-line-short{width:60%}.ob-theme-label{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-top:8px;transition:color .6s}.ob-last-links{display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:8px}.ob-feedback-btn{background:var(--accent);color:white;border:none;border-radius:20px;padding:10px 24px;font-size:13px;font-weight:700;cursor:pointer;font-family:Lato,sans-serif;text-decoration:none;transition:transform .2s,box-shadow .2s}.ob-feedback-btn:hover{transform:scale(1.04);box-shadow:0 4px 16px rgba(220,114,67,.3)}.ob-socials{display:flex;align-items:center;gap:8px;font-size:13px}.ob-social-link{color:var(--primary);text-decoration:none;font-weight:700;transition:color .2s}.ob-social-link:hover{color:var(--accent)}.ob-social-sep{color:#c4a898}.ob-built-by{font-size:12px;color:#a65a6e}.ob-built-by strong{color:var(--primary)}.ob-nav{display:flex;align-items:center;justify-content:space-between;margin-top:20px;padding-top:16px;border-top:1px solid #f0e0d0}.ob-nav-btn{background:none;border:1.5px solid #e0cfc0;border-radius:8px;padding:8px 16px;font-size:16px;cursor:pointer;color:var(--primary);transition:all .15s;font-family:Lato,sans-serif}.ob-nav-btn:hover:not(:disabled){border-color:var(--primary);background:#f5ede3}.ob-nav-btn:disabled{opacity:.3;cursor:not-allowed}.ob-nav-done{background:var(--primary);color:white;border-color:var(--primary);font-size:13px;font-weight:700;letter-spacing:.5px}.ob-nav-done:hover{background:var(--accent)!important;border-color:var(--accent)!important}.ob-dots{display:flex;gap:6px;align-items:center}.ob-dot-btn{width:8px;height:8px;border-radius:50%;border:none;background:#e0cfc0;cursor:pointer;padding:0;transition:all .2s}.ob-dot-btn.active{background:var(--primary);transform:scale(1.3)}@media (max-width:640px){.ob-modal{padding:28px 24px 20px;min-height:auto}.ob-title{font-size:22px}.ob-animation-container{min-height:140px}}.ob-app-preview{opacity:0;transform:translateY(8px);transition:opacity .5s ease,transform .5s ease}.ob-app-preview.ob-visible{opacity:1;transform:translateY(0)}.ob-app-layout-mini{display:flex;gap:10px;width:100%;max-width:420px;height:200px;border:1.5px solid #e8d8c4;border-radius:12px;overflow:hidden;background:var(--bg)}.ob-sidebar-mini{width:100px;background:#ede3d8;padding:10px 8px;display:flex;flex-direction:column;gap:3px;flex-shrink:0;font-size:9px;font-family:Lato,sans-serif}.ob-sidebar-label-mini{font-size:7px;font-weight:700;letter-spacing:1.5px;color:var(--gold);margin-bottom:4px}.ob-sidebar-item{padding:4px 6px;border-radius:5px;color:#6b4a5e;font-size:9px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:background .15s}.ob-sidebar-item.active{background:var(--primary);color:white}.ob-sidebar-divider{border:none;border-top:1px solid #e8d8c4;margin:3px 0}.ob-main-mini{flex:1;padding:8px;display:flex;flex-direction:column;gap:6px;overflow:hidden;background:var(--bg)}.ob-save-bar-mini{display:flex;gap:4px;align-items:center;background:white;border:1px solid #e0cfc0;border-radius:6px;padding:4px 6px;flex-shrink:0}.ob-save-input-mini{flex:1;color:#c4a898;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ob-save-btn-mini,.ob-save-input-mini{font-size:7px;font-family:Lato,sans-serif}.ob-save-btn-mini{background:var(--accent);color:white;border-radius:4px;padding:2px 6px;font-weight:700;flex-shrink:0}.ob-cards-mini{gap:5px}.ob-card-mini-full,.ob-cards-mini{display:flex;flex-direction:column;overflow:hidden}.ob-card-mini-full{background:white;border:1px solid #e8d8c4;border-radius:6px}.ob-card-mini-image{height:32px;background:linear-gradient(135deg,#e8d8c4,var(--accent));display:flex;align-items:center;justify-content:center;font-size:16px}.ob-card-mini-body{padding:4px 6px}.ob-card-mini-title{font-size:8px;font-weight:700;color:var(--primary);font-family:Playfair Display,serif;margin-bottom:3px}.ob-card-mini-tags{display:flex;gap:2px;flex-wrap:wrap}.ob-card-image-full{width:100%;height:70px;background:linear-gradient(135deg,#e8d8c4,var(--accent));border-radius:8px 8px 0 0;display:flex;align-items:center;justify-content:center;font-size:32px}.ob-card-below{padding:8px 12px;text-align:left}.ob-recipe-card-mini{display:flex;flex-direction:column;background:#fff;border:1.5px solid #e8d8c4;border-radius:12px;width:100%;max-width:320px;overflow:hidden;opacity:0;transform:scale(.9) translateY(10px);transition:opacity .3s,transform .3s}.ob-recipe-card-mini.ob-pop-in{opacity:1;transform:scale(1) translateY(0)}.ob-scroll-card-full{background:white;border:1px solid #e8d8c4;border-radius:8px;overflow:hidden;margin-bottom:6px}.ob-scroll-card-image{width:100%;height:40px;background:linear-gradient(135deg,#e8d8c4,var(--accent));display:flex;align-items:center;justify-content:center;font-size:20px}.ob-scroll-card-body{padding:6px 8px}.ob-card-tag-row{display:flex;gap:4px;margin-bottom:3px}.ob-scroll-card-title{font-family:Playfair Display,serif;font-size:11px;font-weight:700;color:var(--primary);margin-bottom:2px}.ob-scroll-card-meta{font-size:9px;color:#a65a6e}.ob-recipe-cards-col{display:flex;flex-direction:column;gap:5px}.ob-recipe-card-chip{display:flex;align-items:center;gap:6px;background:white;border:1px solid #e8d8c4;border-radius:6px;padding:4px 8px;font-size:11px;font-weight:600;color:var(--primary);font-family:Lato,sans-serif;transition:all .3s}.ob-chip-emoji{font-size:14px}.ob-chip-text{font-size:10px}.ob-chip-moving{transform:translateX(8px) scale(1.05);background:var(--accent);color:white;border-color:var(--accent)}.ob-chip-done{opacity:.35}.ob-mini-chip-card{display:flex;flex-direction:column;align-items:center;gap:1px;background:none;border:1.5px solid;border-radius:5px;padding:3px 4px;animation:chipDrop .3s ease}.ob-mini-chip-card.ob-chip-waiting{opacity:.6}.ob-compare-animation{gap:10px;min-height:180px}.ob-compare-cards{display:flex;gap:10px;justify-content:center;opacity:0;transform:translateY(6px);transition:opacity .4s,transform .4s}.ob-compare-cards.ob-visible{opacity:1;transform:translateY(0)}.ob-compare-card-mini{background:white;border:1.5px solid #e8d8c4;border-radius:10px;overflow:hidden;width:130px;text-align:center}.ob-compare-image{width:100%;height:50px;background:linear-gradient(135deg,#e8d8c4,var(--accent));display:flex;align-items:center;justify-content:center;font-size:24px}.ob-compare-card-title{font-family:Playfair Display,serif;font-size:10px;font-weight:700;color:var(--primary);padding:6px 8px 2px}.ob-compare-result{background:white;border:1.5px solid #e8d8c4;border-radius:10px;padding:10px 14px;width:100%;max-width:300px;animation:slideIn .3s ease forwards}.ob-compare-result-label{font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--gold);margin-bottom:6px}.ob-compare-result-text{font-size:10px;color:#6b4a5e;line-height:1.6;font-style:italic}.ob-grocery-layout{display:flex;align-items:flex-start;gap:10px;width:100%;justify-content:center}.ob-recipe-stacks{display:flex;flex-direction:column;gap:6px;opacity:0;transition:opacity .4s}.ob-recipe-stacks.ob-visible{opacity:1}.ob-recipe-stack{background:white;border:1.5px solid #e8d8c4;border-radius:8px;padding:6px 10px;min-width:120px;transition:opacity .3s,transform .3s}.ob-recipe-stack.ob-merging{opacity:.5;filter:blur(.5px);transform:none}.ob-stack-header{display:flex;align-items:center;gap:5px;margin-bottom:4px;font-size:11px}.ob-stack-name{font-weight:700;color:var(--primary);font-family:Lato,sans-serif}.ob-stack-ingredient{font-size:9px;color:#a65a6e;padding:1px 0;font-family:Lato,sans-serif}.ob-grocery-arrow{font-size:20px;color:var(--gold);margin-top:20px;flex-shrink:0}.ob-combined-header{font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--gold);margin-bottom:6px}.ob-theme-hex-row{display:flex;gap:6px;margin-bottom:8px;justify-content:center}.ob-theme-hex-item{display:flex;align-items:center;gap:4px;background:rgba(255,255,255,.3);border-radius:4px;padding:3px 6px}.ob-theme-hex-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.ob-theme-hex-value{font-size:8px;font-family:monospace;font-weight:700;transition:color .7s}.ob-social-icon{color:#a65a6e;transition:color .2s,transform .2s;display:flex}.ob-social-icon:hover{color:var(--primary);transform:scale(1.15)}.kofi-floating-btn,.ob-slide-centered{justify-content:center}.kofi-floating-btn{position:fixed;bottom:60px;right:16px;width:48px;height:48px;border-radius:50%;background:#ff5e5b;border:none;cursor:pointer;display:flex;align-items:center;box-shadow:0 4px 16px rgba(255,94,91,.35);z-index:80;transition:transform .2s,box-shadow .2s}.kofi-floating-btn:hover{transform:scale(1.1);box-shadow:0 6px 24px rgba(255,94,91,.45)}.kofi-overlay{position:fixed;inset:0;background:rgba(30,20,30,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;display:flex;align-items:center;justify-content:center;padding:24px}.kofi-panel{position:relative;width:100%;max-width:400px;max-height:85vh;overflow-y:auto;border-radius:16px;background:#f9f9f9;box-shadow:0 24px 80px rgba(0,0,0,.3)}.kofi-close{position:absolute;top:8px;right:12px;background:none;border:none;font-size:18px;color:#999;cursor:pointer;z-index:10;padding:4px;transition:color .2s}.kofi-close:hover{color:#333}@media (max-width:768px){.kofi-floating-btn{bottom:56px;right:12px;width:42px;height:42px}.kofi-overlay{padding:0;align-items:flex-end}.kofi-panel{max-width:100%;border-radius:20px 20px 0 0;max-height:80vh}}.footer{position:fixed;bottom:0;left:0;right:0;height:48px;background:var(--bg);border-top:1px solid #e8d8c4;display:flex;align-items:center;justify-content:space-between;padding:0 32px;z-index:90}.footer-text{font-size:13px;color:#a65a6e}.footer-text strong{color:var(--primary)}.footer-links{display:flex;gap:16px;align-items:center}.footer-icon{color:#a65a6e;transition:color .2s,transform .2s;display:flex}.footer-icon:hover{color:var(--primary);transform:scale(1.15)}.dark-toggle{background:none;border:none;cursor:pointer;color:#a65a6e;display:flex;align-items:center;padding:4px;transition:color .2s,transform .2s}.dark-toggle:hover{color:var(--primary);transform:scale(1.15)}.toast-container{position:fixed;bottom:60px;left:50%;transform:translateX(-50%);z-index:500;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}.toast{background:var(--primary);color:white;padding:10px 20px;border-radius:20px;font-size:13px;font-weight:600;font-family:Lato,sans-serif;box-shadow:0 4px 16px rgba(58,42,56,.25);animation:toastIn .2s ease}@keyframes toastIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.swatch-color{flex:1;display:block;background-color:var(--swatch-color)}.modal-overlay,.settings-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.grocery-panel-header,.planner-recipe-chip,.recipe-summary{-webkit-user-select:none;user-select:none}.auth-modal{max-width:440px}.auth-modal-body{gap:16px!important}.auth-tabs{display:flex;gap:4px;background:#f5ede3;border-radius:10px;padding:4px}.auth-tab{flex:1;padding:8px 16px;border:none;border-radius:8px;font-size:13px;font-weight:700;font-family:Lato,sans-serif;cursor:pointer;transition:all .15s;background:none;color:#6b4a5e}.auth-tab:hover{color:var(--primary)}.auth-tab.active{background:var(--primary);color:white}.google-auth-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px;border:1.5px solid #e0cfc0;border-radius:8px;background:#fff;font-size:14px;font-weight:600;font-family:Lato,sans-serif;color:#3a2a38;cursor:pointer;transition:border-color .2s,box-shadow .2s,transform .2s}.google-auth-btn:hover{border-color:var(--primary);box-shadow:0 2px 8px rgba(94,68,90,.12);transform:scale(1.01)}.google-auth-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-divider{display:flex;align-items:center;gap:12px;color:#c4a898;font-size:12px;font-weight:600}.auth-divider:after,.auth-divider:before{content:"";flex:1;border-top:1px solid #e0cfc0}.auth-field{margin-bottom:12px}.auth-field .form-label{margin-bottom:6px}.auth-password-hint{font-size:11px;color:#c4a898;margin-top:4px}.auth-submit-btn{width:100%;margin-top:4px}.auth-reassurance{font-size:12px;color:#a65a6e;text-align:center;line-height:1.5}.auth-input{width:100%!important}.auth-nudge{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,var(--primary),color-mix(in srgb,var(--primary) 80%,var(--accent)));border-radius:12px;padding:14px 18px;margin-bottom:24px;color:white;box-shadow:0 2px 12px rgba(94,68,90,.15)}.auth-nudge-content{flex:1;display:flex;align-items:center;gap:16px}.auth-nudge-text{font-size:13px;line-height:1.5;flex:1}.auth-nudge-text strong{font-weight:700}.auth-nudge-btn{background:white;color:var(--primary);border:none;border-radius:20px;padding:8px 18px;font-size:12px;font-weight:700;letter-spacing:.5px;cursor:pointer;font-family:Lato,sans-serif;white-space:nowrap;transition:transform .2s,box-shadow .2s;flex-shrink:0}.auth-nudge-btn:hover{transform:scale(1.04);box-shadow:0 4px 12px rgba(0,0,0,.15)}.auth-nudge-dismiss{background:none;border:none;color:rgba(255,255,255,.7);cursor:pointer;font-size:16px;padding:4px;transition:color .2s;flex-shrink:0}.auth-nudge-dismiss:hover{color:white}.auth-nudge-modal{max-width:420px}.auth-nudge-modal-body{text-align:center;padding:32px 28px!important}.auth-nudge-modal-emoji{font-size:48px;margin-bottom:16px}.auth-nudge-modal-title{font-family:Playfair Display,serif;font-size:22px;color:var(--primary);margin-bottom:8px}.auth-nudge-modal-text{font-size:14px;color:#6b4a5e;line-height:1.6;margin-bottom:20px}.auth-nudge-modal-actions{display:flex;flex-direction:column;gap:10px}.auth-nudge-modal-signup{background:var(--accent);color:white;border:none;border-radius:8px;padding:12px 24px;font-size:14px;font-weight:700;cursor:pointer;font-family:Lato,sans-serif;transition:background .2s,transform .2s}.auth-nudge-modal-signup:hover{background:#c45e30;transform:scale(1.02)}.auth-nudge-modal-later{background:none;border:none;color:#a65a6e;font-size:13px;cursor:pointer;font-family:Lato,sans-serif;padding:8px;transition:color .2s}.auth-nudge-modal-later:hover{color:var(--primary)}.sidebar-account{display:flex;flex-direction:column;gap:4px}.sidebar-account-info{display:flex;align-items:center;gap:8px;padding:8px 10px}.sidebar-account-icon{font-size:14px;flex-shrink:0}.sidebar-account-email{color:#6b4a5e;font-weight:600;flex:1}.sidebar-signout-btn{border:none;padding:4px 10px 4px 32px;text-align:left;transition:color .2s}.sidebar-signin-btn{display:flex;align-items:center;gap:8px;background:none;border:1.5px solid var(--accent);border-radius:8px;padding:8px 10px;font-size:12px;color:var(--accent);cursor:pointer;font-family:Lato,sans-serif;font-weight:700;transition:background .15s,color .15s,transform .15s;text-align:left}.sidebar-signin-btn:hover{background:var(--accent);color:white;transform:scale(1.02)}.sidebar-account-card{background:color-mix(in srgb,var(--primary) 8%,transparent);border:1.5px solid color-mix(in srgb,var(--primary) 15%,transparent);border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:8px}.sidebar-account-row{display:flex;align-items:center;gap:10px}.sidebar-account-avatar{width:28px;height:28px;border-radius:50%;background:var(--primary);color:white;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:Lato,sans-serif;text-transform:uppercase}.sidebar-account-details{flex:1;min-width:0}.sidebar-account-email{font-size:11px;color:var(--primary);font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-account-status{font-size:9px;color:#4e6646;font-weight:700;letter-spacing:.5px;display:flex;align-items:center;gap:3px}.sidebar-signout-btn{background:none;border:1px solid color-mix(in srgb,var(--primary) 20%,transparent);border-radius:6px;color:#a65a6e;font-size:11px;font-weight:700;cursor:pointer;font-family:Lato,sans-serif;padding:5px 0;text-align:center;transition:all .15s;width:100%}.sidebar-signout-btn:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 5%,transparent)}.mobile-top-bar{display:none}@media (max-width:768px){.mobile-top-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg);border-bottom:1.5px solid #e8d8c4;position:sticky;top:0;z-index:200;gap:12px}html.dark .mobile-top-bar{border-color:var(--border);background:var(--bg)}.mobile-account-btn,.mobile-menu-btn{background:none;border:none;cursor:pointer;color:var(--primary);display:flex;align-items:center;justify-content:center;padding:6px;border-radius:8px;transition:background .15s;flex-shrink:0}.mobile-account-btn:hover,.mobile-menu-btn:hover{background:#f0e4d4}html.dark .mobile-account-btn,html.dark .mobile-menu-btn{color:var(--text)}html.dark .mobile-account-btn:hover,html.dark .mobile-menu-btn:hover{background:var(--raised)}.mobile-top-bar-title{font-family:Playfair Display,serif;font-size:20px;font-weight:700;color:var(--primary);flex:1;text-align:center}.mobile-account-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);color:white;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:Lato,sans-serif;text-transform:uppercase}html.dark .mobile-account-avatar{background:var(--accent)}.mobile-sidebar-overlay{display:block;opacity:0;position:fixed;inset:0;background:rgba(30,20,30,.5);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:250;pointer-events:none;transition:opacity .25s ease}.mobile-sidebar-overlay.active{opacity:1;pointer-events:all}.collections-sidebar{position:fixed;left:0;top:0;height:100vh;width:280px;margin:0;border-radius:0 16px 16px 0;z-index:300;transform:translateX(-100%);transition:transform .25s ease;padding:24px 16px 32px;overflow-y:auto}.collections-sidebar.mobile-open,.collections-sidebar:hover{transform:translateX(0);box-shadow:4px 0 32px rgba(0,0,0,.2)}.sidebar-spacer{flex:1}.sidebar-label{display:block}.app-layout{flex-direction:column;padding-top:0;max-width:100%}.main-content-wrapper{width:100%}.main-content{padding:20px 16px 100px;max-width:100%}.header{display:none}.form-section{margin-bottom:24px;padding:20px 16px}.form-row{flex-direction:column;gap:10px}.submit-btn{width:100%}.search-row{flex-wrap:wrap;gap:8px}.sort-select{flex:1;min-width:0}.filter-row{gap:6px}.recipe-columns{grid-template-columns:1fr;gap:16px}.sticky-actions{justify-content:center;top:8px;gap:6px}.add-collection-btn,.add-planner-btn,.compare-btn,.deselect-btn{padding:8px 12px;font-size:11px}.grid-view{grid-template-columns:repeat(2,1fr);gap:10px}.list-source,.list-tags{display:none}.week-grid{grid-template-columns:repeat(2,1fr);gap:8px}.compare-cards-grid{grid-template-columns:1fr!important}.grocery-panel{left:8px;right:8px;width:auto;bottom:48px}.mobile-image-actions{display:flex;position:absolute;left:10px;right:10px;top:50%;transform:translateY(-50%);justify-content:space-between;z-index:4;pointer-events:none}.mobile-action-btn{width:40px;height:40px;border-radius:50%;border:2.5px solid rgba(255,255,255,.6);cursor:pointer;display:flex;align-items:center;justify-content:center;pointer-events:all;transition:all .15s}.mobile-select-btn{background:rgba(80,60,80,.5)}.mobile-select-btn.mobile-selected{background:var(--primary);border-color:white}.mobile-delete-btn{background:rgba(180,40,40,.6)}.mobile-delete-btn:hover{background:rgba(200,40,40,.9)}.overlay-icons{display:none}.settings-sidebar{position:fixed;right:0;top:0;height:100vh;margin:0;border-radius:16px 0 0 16px;z-index:400;width:290px}.settings-overlay{display:block;position:fixed;inset:0;background:rgba(58,42,56,.4);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:399}.modal-overlay{padding:0;align-items:flex-end}.modal{border-radius:20px 20px 0 0;max-height:92vh}.auth-modal{max-width:100%}}@media (max-width:900px) and (min-width:769px){.week-grid{grid-template-columns:repeat(4,1fr)}.grid-view{grid-template-columns:repeat(2,1fr)}.settings-sidebar{position:fixed;right:0;top:0;height:100vh;margin:0;border-radius:16px 0 0 16px;z-index:400}.settings-overlay{display:block;position:fixed;inset:0;background:rgba(58,42,56,.4);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:399}}