:root{--app-background-image:url(/images/backgrounds/cookbook-desktop.webp);--bg-color:#14130f;--bg-secondary:#1e1c18a3;--surface:#1e1c189e;--surface-elevated:#28251fc7;--text-primary:#f5f2ec;--text-secondary:#a8a39b;--text-muted:#6b6760;--accent-primary:#e85d2b;--accent-primary-hover:#cf4a1e;--accent-primary-soft:#e85d2b2b;--accent-secondary:#2d5f3f;--accent-warm:#f4c430;--accent-danger:#c0392b;--card-bg:var(--surface);--card-border:#f5f2ec21;--chrome-bg:#1e1c18b8;--topbar-bg:#14130fa3;--control-overlay-bg:#1e1c18cc;--radius-sm:12px;--radius-md:16px;--radius-lg:24px;--radius-xl:32px;--radius-pill:999px;--shadow-sm:0 8px 24px #0003;--shadow-md:0 16px 42px #00000052;--shadow-lg:0 28px 80px #0000007a;--shadow-glass:0 20px 64px #00000061;--glass-shadow:var(--shadow-md);--transition-fast:.15s ease;--transition-base:.22s ease;--transition-spring:.38s cubic-bezier(.34, 1.56, .64, 1);--transition:var(--transition-base);--nav-rail-width:72px;--nav-rail-expanded:226px;--topbar-height:64px;--bottom-nav-height:72px;--bp-mobile:600px;--bp-tablet:900px;--bp-desktop:1200px}:root[data-theme=light]{--app-background-image:url(/images/backgrounds/cookbook-desktop-light.webp);--bg-color:#eeeae3;--bg-secondary:#fffcf78a;--surface:#fffcf7a3;--surface-elevated:#fffc;--text-primary:#211c18;--text-secondary:#6f6259;--text-muted:#98897d;--accent-primary-soft:#e85d2b1f;--card-bg:var(--surface);--card-border:#5c453324;--chrome-bg:#fffcf7ad;--topbar-bg:#fffcf7a8;--control-overlay-bg:#fffcf7d1;--shadow-sm:0 8px 24px #50341f14;--shadow-md:0 16px 42px #50341f1c;--shadow-lg:0 28px 80px #50341f26;--shadow-glass:0 20px 64px #50341f21}*{box-sizing:border-box;margin:0;padding:0}html,body{background-color:var(--bg-color);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Segoe UI,sans-serif;overflow-x:hidden}a{color:inherit;text-decoration:none}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}.app-shell{grid-template-columns:1fr;min-height:100vh;display:grid}.app-main{min-width:0;max-width:100vw;padding-bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom,0px) + 1rem)}@media (min-width:900px){.app-shell{grid-template-columns:var(--nav-rail-width) 1fr}.app-shell[data-nav-expanded=true]{grid-template-columns:var(--nav-rail-expanded) 1fr}.app-main{max-width:calc(100vw - var(--nav-rail-width));grid-column:2;padding-bottom:2rem}.app-shell[data-nav-expanded=true] .app-main{max-width:calc(100vw - var(--nav-rail-expanded))}}.glass-card{background:var(--surface);border:1px solid var(--card-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base), transform var(--transition-base);overflow:hidden}.install-app-card{gap:1rem;padding:1.25rem;display:flex}.install-app-card__icon{border-radius:var(--radius-md);color:#fff;background:linear-gradient(135deg, var(--accent-primary), var(--accent-warm));flex:none;place-items:center;width:48px;height:48px;display:grid}.install-app-card__content{gap:.8rem;min-width:0;display:grid}.install-app-card__content h2{margin:0;font-size:1.15rem}.install-app-card__content p{color:var(--text-secondary);line-height:1.5}.install-app-card__button{width:fit-content}.install-app-card__instructions{border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-secondary);align-items:flex-start;gap:.6rem;padding:.75rem;line-height:1.4;display:flex}.install-app-card__instructions svg{color:var(--accent-primary);flex:none}.install-app-card__status{font-size:.875rem}@media (max-width:520px){.install-app-card{display:grid}.install-app-card__button{width:100%}}@media (hover:hover){.glass-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}}.container{width:100%;max-width:1200px;margin:0 auto;padding:1.5rem 1.25rem}@media (max-width:479px){.container{padding:1rem .5rem}}@media (min-width:900px){.container{padding:2rem}}.btn{border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);border:1px solid #0000;justify-content:center;align-items:center;gap:.5rem;min-height:44px;padding:.75rem 1.5rem;font-family:inherit;font-weight:600;text-decoration:none;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary);box-shadow:var(--shadow-sm)}.btn-secondary{background:var(--surface);color:var(--text-primary);border:1px solid var(--card-border)}.btn-secondary:hover{background:var(--bg-secondary)}.btn-icon{border-radius:var(--radius-pill);background:var(--surface);color:var(--text-primary);border:1px solid var(--card-border);cursor:pointer;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:.5rem;display:flex}.btn-icon:hover{background:var(--bg-secondary)}.btn-sm{min-height:36px;padding:.45rem .8rem;font-size:.85rem}h1,h2,h3,h4,h5,h6{letter-spacing:-.01em;margin-bottom:.5rem;font-weight:700}h1{font-size:clamp(1.75rem,3vw,2.5rem)}h2{font-size:clamp(1.4rem,2.4vw,1.875rem)}h3{font-size:1.25rem}.text-sm{font-size:.875rem}.text-muted{color:var(--text-secondary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.35s ease-out forwards fadeIn}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.animate-slide-up{animation:slideUp .4s var(--transition-spring) forwards}.bottom-nav{height:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:var(--chrome-bg);-webkit-backdrop-filter:saturate(180%)blur(20px);border-top:1px solid var(--card-border);z-index:1000;justify-content:space-around;align-items:center;padding-left:.5rem;padding-right:.5rem;display:flex;position:fixed;bottom:0;left:0;right:0}@media (min-width:900px){.bottom-nav{display:none}}.nav-item{color:var(--text-secondary);transition:color var(--transition-fast);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.2rem;min-width:0;min-height:44px;font-size:.7rem;font-weight:500;line-height:1.05;text-decoration:none;display:flex}.nav-item span{overflow-wrap:anywhere;max-width:100%}.nav-item.active{color:var(--accent-primary)}.nav-item:hover{color:var(--text-primary)}.side-rail{width:var(--nav-rail-width);background:var(--surface);border-right:1px solid var(--card-border);z-index:100;overscroll-behavior:contain;flex-direction:column;gap:.25rem;height:100dvh;padding:1rem .75rem;display:none;position:fixed;inset:0 auto 0 0;overflow-y:auto}@media (min-width:900px){.side-rail{display:flex}.app-shell[data-nav-expanded=true] .side-rail{width:var(--nav-rail-expanded)}}.side-rail__brand{letter-spacing:-.01em;align-items:center;gap:.6rem;padding:.5rem .6rem 1.25rem;font-size:1.1rem;font-weight:700;display:flex}.side-rail__brand-mark{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--accent-primary), var(--accent-warm));color:#fff;flex-shrink:0;place-items:center;width:36px;height:36px;font-weight:800;display:grid}.side-rail__item{border-radius:var(--radius-md);color:var(--text-secondary);transition:background var(--transition-fast), color var(--transition-fast);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.85rem;width:100%;padding:.7rem .75rem;font-family:inherit;font-size:.95rem;font-weight:500;display:flex}.side-rail__item:hover{background:var(--bg-secondary);color:var(--text-primary)}.side-rail__item.active{background:var(--accent-primary-soft);color:var(--accent-primary)}.side-rail__item svg{flex-shrink:0}.side-rail__spacer{flex:1}.side-rail__user{border-radius:var(--radius-md);border-top:1px solid var(--card-border);color:var(--text-secondary);transition:background var(--transition-fast), color var(--transition-fast);align-items:center;gap:.65rem;margin-top:.5rem;padding:.85rem .75rem .6rem;font-size:.85rem;display:flex}.side-rail__user:hover{background:var(--bg-secondary);color:var(--text-primary)}.side-rail__user.active{background:var(--accent-primary-soft);color:var(--accent-primary)}.side-rail__avatar{border-radius:var(--radius-pill);background:var(--accent-primary-soft);width:32px;height:32px;color:var(--accent-primary);flex-shrink:0;place-items:center;font-weight:700;display:grid}.side-rail[data-expanded=false] .side-rail__label,.side-rail[data-expanded=false] .side-rail__brand-text,.side-rail[data-expanded=false] .side-rail__user-text{display:none}.side-rail[data-expanded=false] .side-rail__item{justify-content:center;padding:.7rem}.side-rail[data-expanded=false] .side-rail__brand{justify-content:center;padding:.5rem 0 1.25rem}.topbar{background:var(--topbar-bg);-webkit-backdrop-filter:saturate(180%)blur(16px);border-bottom:1px solid var(--card-border);z-index:50;align-items:center;gap:.75rem;min-height:56px;padding:0 1rem;display:flex;position:sticky;top:0}@media (min-width:900px){.topbar{min-height:var(--topbar-height);gap:1rem;padding:0 1.5rem}}.topbar__title{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;min-width:0;margin-right:auto;font-size:1rem;font-weight:600;overflow:hidden}.topbar__search{background:var(--bg-secondary);border-radius:var(--radius-pill);min-width:280px;color:var(--text-secondary);transition:border-color var(--transition-fast), background var(--transition-fast);border:1px solid #0000;align-items:center;gap:.5rem;padding:.5rem .85rem;display:none}@media (min-width:900px){.topbar__search{display:flex}}.topbar__search:focus-within{border-color:var(--accent-primary);background:var(--surface)}.topbar__search input{font:inherit;color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;min-width:0}.topbar__user{color:var(--text-secondary);flex-shrink:0;align-items:center;gap:.5rem;font-size:.85rem;display:flex}.topbar__user form{margin:0}.topbar__user button,.topbar__auth-link{border:1px solid var(--card-border);border-radius:var(--radius-md);cursor:pointer;color:var(--text-secondary);transition:background var(--transition-fast);background:0 0;padding:.4rem .75rem;font-family:inherit;font-size:.8rem}.topbar__user button:hover,.topbar__auth-link:hover{background:var(--bg-secondary);color:var(--text-primary)}.app-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--card-border);border-radius:var(--radius-pill);border:2px solid var(--bg-color)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.auth-page{isolation:isolate;background:linear-gradient(115deg, #e85d2b29, transparent 32%), linear-gradient(245deg, #2d5f3f3d, transparent 38%), linear-gradient(180deg, var(--bg-color), var(--bg-secondary));justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative;overflow:hidden}.auth-page:before,.auth-page:after{content:"";z-index:-2;pointer-events:none;position:absolute;inset:-20%}.auth-page:before{background:linear-gradient(90deg,#f5f2ec0b 1px,#0000 1px) 0 0/84px 84px,linear-gradient(#f5f2ec0b 1px,#0000 1px) 0 0/84px 84px,linear-gradient(135deg,#0000 0 42%,#f4c43014 42% 44%,#0000 44% 100%) 0 0/360px 360px;animation:18s linear infinite authGridDrift;transform:rotate(-8deg)scale(1.08)}.auth-page:after{content:"CookBookPRO    My recipes    Cart    Top meals    Meal planner    Smart search    CookBookPRO    Grocery list    ";z-index:-1;color:#f5f2ec09;letter-spacing:.02em;white-space:nowrap;text-shadow:0 1px #e85d2b0a;font-size:clamp(3rem,7.5vw,6.5rem);font-weight:800;line-height:1;animation:18s linear infinite authBrandMarquee;inset:auto -12% 8%;transform:rotate(-7deg)}.auth-form{z-index:1;-webkit-backdrop-filter:blur(18px)saturate(145%);border:1px solid var(--card-border);border-radius:var(--radius-lg);background:#1e1c18db;flex-direction:column;gap:12px;width:100%;max-width:400px;padding:32px 28px;display:flex;position:relative;box-shadow:0 24px 80px #0000006b,inset 0 1px #ffffff09}@keyframes authGridDrift{0%{background-position:0 0,0 0,0 0}to{background-position:84px 84px,84px 84px,360px 360px}}@keyframes authBrandMarquee{0%{transform:translate(0)rotate(-7deg)}to{transform:translate(-34%)rotate(-7deg)}}@media (max-width:520px){.auth-page{align-items:stretch;padding:18px}.auth-form{align-self:center;padding:28px 22px}}@media (prefers-reduced-motion:reduce){.auth-page:before,.auth-page:after{animation:none!important}}.auth-form h1{margin-bottom:8px;font-size:1.5rem;font-weight:700}.auth-form label{color:var(--text-secondary);margin-top:6px;font-size:13px;font-weight:500}.auth-form input{border:1px solid var(--card-border);border-radius:var(--radius-md);background:var(--bg-color);color:var(--text-primary);transition:border-color var(--transition-fast);padding:11px 13px;font-family:inherit;font-size:15px}.auth-form input:focus{border-color:var(--accent-primary);outline:none}.password-input{align-items:center;display:flex;position:relative}.password-input input{width:100%;padding-right:44px}.auth-form .password-input__toggle{width:30px;height:30px;color:var(--text-secondary);background:0 0;border:none;border-radius:999px;justify-content:center;align-items:center;margin:0;padding:6px;display:inline-flex;position:absolute;right:10px}.auth-form .password-input__toggle:hover{background:var(--surface-elevated);color:var(--text-primary)}.auth-form .password-input__toggle:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.auth-form button{background:var(--accent-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);border:none;margin-top:12px;padding:12px;font-family:inherit;font-size:15px;font-weight:600}.auth-form button:hover{background:var(--accent-primary-hover)}.auth-form button:disabled{opacity:.6;cursor:not-allowed}.auth-error{color:var(--accent-danger);margin:2px 0;font-size:13px;list-style:none}.auth-footer{text-align:center;color:var(--text-secondary);margin-top:12px;font-size:14px}.auth-footer a{color:var(--accent-primary);font-weight:600}.settings-card{gap:1rem;padding:1.25rem;display:grid}.settings-card__title{margin:.15rem 0 0;font-size:1.15rem}.theme-toggle{border:1px solid var(--card-border);border-radius:var(--radius-md);background:var(--bg-secondary);grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem;padding:.25rem;display:grid}.theme-toggle__option{border-radius:calc(var(--radius-md) - 3px);min-height:44px;color:var(--text-secondary);font:inherit;cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;gap:.5rem;font-weight:600;display:inline-flex}.theme-toggle__option:hover{color:var(--text-primary)}.theme-toggle__option.active{background:var(--surface);color:var(--text-primary);border-color:var(--card-border);box-shadow:var(--shadow-sm)}.user-nav{z-index:50;background:var(--chrome-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-pill);border:1px solid var(--card-border);align-items:center;gap:8px;padding:6px 8px 6px 14px;font-size:13px;display:flex;position:fixed;top:12px;right:16px}@media (min-width:900px){.user-nav{display:none}}.user-nav form{margin:0}.user-nav button{background:var(--surface);border:1px solid var(--card-border);border-radius:var(--radius-pill);cursor:pointer;padding:5px 10px;font-family:inherit;font-size:12px}.kb-help{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:2100;background:#00000073;place-items:center;padding:1rem;animation:.2s ease-out fadeIn;display:grid;position:fixed;inset:0}.kb-help__panel{background:var(--surface);border:1px solid var(--card-border);border-radius:var(--radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow-lg);padding:1.25rem}.kb-help__header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.kb-help__list{flex-direction:column;gap:.5rem;margin:0 0 1rem;padding:0;list-style:none;display:flex}.kb-help__list li{border-radius:var(--radius-sm);background:var(--bg-secondary);justify-content:space-between;align-items:center;padding:.5rem .65rem;display:flex}.kb-help__label{font-size:.9rem}.kb-help__keys{gap:.3rem;display:inline-flex}.kb-help kbd,.kb-help__hint kbd{background:var(--surface);border:1px solid var(--card-border);color:var(--text-primary);text-align:center;border-bottom-width:2px;border-radius:4px;min-width:22px;padding:.1rem .45rem;font-family:inherit;font-size:.78rem;font-weight:600}.kb-help__hint{margin:0;font-size:.8rem}.compare-bar{left:50%;bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom,0px) + .75rem);background:var(--surface);border:1px solid var(--card-border);border-radius:var(--radius-pill);box-shadow:var(--shadow-lg);z-index:1100;max-width:calc(100vw - 2rem);animation:slideUp .3s var(--transition-spring);align-items:center;gap:.85rem;padding:.55rem .85rem;display:flex;position:fixed;transform:translate(-50%)}@media (min-width:900px){.compare-bar{bottom:1.25rem}}.compare-bar__count{white-space:nowrap;align-items:center;gap:.4rem;font-size:.85rem;display:inline-flex}.compare-bar__chips{flex-wrap:nowrap;gap:.35rem;display:none;overflow:hidden}@media (min-width:720px){.compare-bar__chips{display:inline-flex}}.compare-bar__chip{background:var(--bg-secondary);border-radius:var(--radius-pill);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:.3rem;max-width:180px;padding:.25rem .65rem;font-size:.78rem;display:inline-flex;overflow:hidden}.compare-bar__chip button{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-pill);background:0 0;border:none;place-items:center;padding:2px;display:grid}.compare-bar__chip button:hover{background:var(--card-border);color:var(--text-primary)}.compare-bar__actions{gap:.4rem;display:flex}.compare-modal{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:2200;background:#0000008c;place-items:center;padding:1rem;animation:.2s ease-out fadeIn;display:grid;position:fixed;inset:0}.compare-modal__panel{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:1100px;max-height:90vh;box-shadow:var(--shadow-lg);border:1px solid var(--card-border);flex-direction:column;display:flex;overflow:hidden}.compare-modal__header{border-bottom:1px solid var(--card-border);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.compare-modal__scroll{padding:0;overflow:auto}.compare-modal__table{border-collapse:collapse;width:100%;font-size:.9rem}.compare-modal__table th,.compare-modal__table td{border-bottom:1px solid var(--card-border);text-align:left;vertical-align:middle;padding:.7rem .85rem}.compare-modal__table th{width:130px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;background:var(--bg-secondary);z-index:1;font-size:.72rem;font-weight:600;position:sticky;left:0}.compare-modal__table td{min-width:160px}.compare-modal__img{object-fit:cover;border-radius:var(--radius-md);width:100%;height:110px}.recipe-peek{display:none}@media (hover:hover) and (min-width:1100px){.recipe-card{position:relative}.recipe-peek{background:var(--surface);border:1px solid var(--card-border);border-radius:var(--radius-lg);width:280px;box-shadow:var(--shadow-lg);z-index:50;pointer-events:none;margin-left:12px;padding:1rem 1.1rem;animation:.18s ease-out fadeIn;display:block;position:absolute;top:0;left:100%}.recipe-card:nth-child(3n) .recipe-peek,.recipe-card:nth-last-child(-n+1) .recipe-peek{margin-left:0;margin-right:12px;left:auto;right:100%}.recipe-peek__title{color:var(--text-primary);margin-bottom:.6rem;font-size:.95rem;font-weight:700}.recipe-peek__section{margin-bottom:.65rem}.recipe-peek__label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-bottom:.25rem;font-size:.65rem;font-weight:700}.recipe-peek ul{color:var(--text-primary);margin:0;padding:0;font-size:.82rem;line-height:1.5;list-style:none}.recipe-peek ul li.more{color:var(--text-secondary);font-style:italic}.recipe-peek p{color:var(--text-primary);-webkit-line-clamp:4;-webkit-box-orient:vertical;margin:0;font-size:.85rem;line-height:1.5;display:-webkit-box;overflow:hidden}.recipe-peek__hint{color:var(--text-muted);border-top:1px dashed var(--card-border);margin-top:.65rem;padding-top:.5rem;font-size:.7rem}}.recipe-compare-toggle{background:var(--control-overlay-bg);color:var(--text-secondary);border:1px solid var(--card-border);border-radius:var(--radius-pill);cursor:pointer;opacity:0;width:42px;height:42px;transition:opacity var(--transition-fast), background var(--transition-fast), color var(--transition-fast);z-index:2;place-items:center;display:grid;position:absolute;top:17px;left:17px}@media (hover:hover){.recipe-card:hover .recipe-compare-toggle{opacity:1}}@media (hover:none){.recipe-compare-toggle{opacity:.95}}.recipe-compare-toggle:hover{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.recipe-compare-toggle.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary);opacity:1}.recipe-card.is-comparing{outline:2px solid var(--accent-primary);outline-offset:-2px}.recipe-share-toggle{left:67px}.recipe-img-container .recipe-compare-toggle{top:10px;left:10px}.recipe-compare-toggle svg{width:20px;height:20px}@media (max-width:899px){.recipe-compare-toggle{opacity:.95;width:48px;height:48px}.recipe-share-toggle{left:73px}.recipe-compare-toggle svg{width:22px;height:22px}}.share-modal{z-index:3000;place-items:center;padding:1rem;display:grid;position:fixed;inset:0}.share-modal__scrim{background:#00000094;position:absolute;inset:0}.share-modal__panel{background:var(--surface);border:1px solid var(--card-border);border-radius:var(--radius-lg);width:min(460px,100%);box-shadow:var(--shadow-lg);flex-direction:column;gap:.85rem;padding:1rem;display:flex;position:relative}.share-modal__header{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.share-modal__header h2{margin:0;font-size:1.1rem}.share-modal__input{border:1px solid var(--card-border);border-radius:var(--radius-sm);background:var(--bg-secondary);width:100%;min-height:44px;color:var(--text-primary);font:inherit;padding:.7rem .8rem}.share-modal__error,.share-accept__error{color:var(--accent-danger);line-height:1.4}.share-page{max-width:1040px}.share-page__header{flex-direction:column;gap:.65rem;margin-bottom:1.25rem;display:flex}.share-page__header h1{margin:0}.share-accept{flex-wrap:wrap;align-items:center;gap:.6rem;margin-top:.35rem;display:flex}.share-accept__message{width:100%;color:var(--accent-warm)}.share-recipe{grid-template-columns:1fr;display:grid}.share-recipe__image{object-fit:cover;width:100%;height:min(360px,48vw);min-height:220px}.share-recipe__body{flex-direction:column;gap:1rem;padding:1.25rem;display:flex}.share-recipe__body h2,.share-recipe__section h3{margin:0}.share-recipe__meta{color:var(--text-secondary);flex-wrap:wrap;gap:.5rem;display:flex}.share-recipe__meta span{border:1px solid var(--card-border);border-radius:var(--radius-pill);background:var(--bg-secondary);padding:.3rem .65rem}.share-recipe__section ul,.share-recipe__section ol{margin:.65rem 0 0 1.2rem;line-height:1.55}.share-plan,.share-cart-menu{padding:1rem}.share-cart-menu h2{margin:0 0 1rem;font-size:1.2rem}.share-cart-menu__list{grid-template-columns:1fr;gap:.75rem;list-style:none;display:grid}.share-cart-menu__item{border:1px solid var(--card-border);border-radius:var(--radius-sm);background:var(--bg-secondary);align-items:center;gap:.75rem;padding:.7rem;display:flex}.share-cart-menu__item img{object-fit:cover;border-radius:6px;flex-shrink:0;width:64px;height:64px}.share-cart-menu__item div{flex-direction:column;gap:.2rem;min-width:0;display:flex}.share-cart-menu__item strong{overflow-wrap:anywhere}.share-cart-menu__item span{color:var(--text-secondary);font-size:.85rem}.share-plan__grid{grid-template-columns:74px repeat(3,minmax(0,1fr));gap:6px;display:grid}.share-plan__corner{background:0 0}.share-plan__slot,.share-plan__day{color:var(--text-secondary);text-align:center;padding:.55rem .4rem;font-size:.78rem;font-weight:700}.share-plan__day{background:var(--bg-secondary);border-radius:var(--radius-sm);flex-direction:column;justify-content:center;display:flex}.share-plan__day .day-full{display:none}.share-plan__cell{border:1px dashed var(--card-border);border-radius:var(--radius-sm);min-height:72px;color:var(--text-muted);flex-direction:column;justify-content:center;gap:.3rem;padding:.35rem;display:flex}.share-plan__cell.filled{background:var(--bg-secondary);color:var(--text-primary);border-style:solid}.share-plan__item{background:var(--accent-primary-soft);overflow-wrap:anywhere;border-radius:6px;padding:.38rem .45rem;font-size:.8rem;font-weight:600;line-height:1.25;display:block}.share-plan__empty{text-align:center}@media (min-width:760px){.share-recipe{grid-template-columns:minmax(280px,380px) 1fr}.share-recipe__image{height:100%;min-height:420px}.share-plan__day .day-full{margin-top:.15rem;font-size:.7rem;font-weight:500;display:inline}}body{isolation:isolate;background:var(--bg-color);position:relative}body:before,body:after{content:"";pointer-events:none;will-change:transform, opacity;position:fixed}body:before{z-index:-2;background-image:var(--app-background-image);background-position:50%;background-repeat:no-repeat;background-size:cover;animation:28s ease-in-out infinite alternate app-background-drift;inset:-3.5%}body:after{z-index:-1;background:radial-gradient(circle at 14% 30%,#2d5f3f14,#0000 36rem),radial-gradient(circle at 84% 74%,#e85d2b1a,#0000 38rem),#14130f0a;animation:20s ease-in-out infinite alternate app-background-sheen;inset:0}@keyframes app-background-drift{0%{transform:translate(-.8%,-.5%)scale(1.015)}50%{transform:translate(.7%,.6%)scale(1.035)}to{transform:translate(-.2%,.9%)scale(1.025)}}@keyframes app-background-sheen{0%{opacity:.72;transform:scale(1)}to{opacity:1;transform:scale(1.04)}}.app-main{position:relative}.glass-card,.filters-section,.meal-planner,.settings-card,.share-modal__panel,.compare-modal__panel,.share-recipe,.share-plan,.share-cart-menu,.auth-form,.modal-container,.ai-search-modal__panel{background:linear-gradient(145deg, #ffffff1a, #ffffff06 55%), var(--surface);box-shadow:inset 0 1px 0 #ffffff2e, inset 0 -1px 0 #ffffff09, var(--shadow-glass);-webkit-backdrop-filter:blur(26px)saturate(155%);border:1px solid #ffffff24}.glass-card{border-radius:var(--radius-lg)}@media (hover:hover){.glass-card:hover{border-color:#ffffff38;transform:translateY(-5px)scale(1.006);box-shadow:inset 0 1px #ffffff3d,0 24px 64px #0004126b}}.side-rail{-webkit-backdrop-filter:blur(28px)saturate(170%);background:linear-gradient(160deg,#ffffff1a,#0000 38%),#1e1c18a8;border:1px solid #ffffff21;border-radius:28px;height:calc(100dvh - 28px);margin:14px 0 14px 14px;box-shadow:inset 0 1px #ffffff24,0 24px 70px #0000006b}.side-rail__brand{border-bottom:1px solid #ffffff14;margin:.15rem .15rem .8rem;padding-bottom:1rem}.side-rail__brand-mark{background:linear-gradient(145deg, #f08a55, var(--accent-primary) 60%, #b94020);border:1px solid #ffffff61;box-shadow:inset 0 1px #fff6,0 10px 24px #e85d2b4d}.side-rail__item{border:1px solid #0000;border-radius:15px;min-height:46px}.side-rail__item:hover{background:#ffffff13;border-color:#ffffff1a}.side-rail__item.active,.side-rail__user.active{background:linear-gradient(135deg,#e85d2b38,#f4c4300d);border-color:#e85d2b57;box-shadow:inset 0 1px #ffffff21}.topbar{border-radius:var(--radius-pill);background:linear-gradient(145deg, #ffffff14, transparent 50%), var(--topbar-bg);-webkit-backdrop-filter:blur(28px)saturate(165%);border:1px solid #ffffff1f;width:min(760px,100% - 3rem);min-height:58px;margin:14px auto 0;top:14px;box-shadow:inset 0 1px #ffffff29,0 18px 48px #0004124d}.topbar__search{background:#ffffff0e;border-color:#ffffff14;width:100%;min-width:0}.topbar__search:focus-within,.home-mobile-search:focus-within{background:#ffffff17;border-color:#e85d2ba3;box-shadow:0 0 0 4px #e85d2b1a}.container{max-width:1320px;padding-top:2.5rem}.home-hero{align-items:center;margin-bottom:1.75rem}.home-hero h1{letter-spacing:-.055em;margin-bottom:.2rem;font-size:clamp(2rem,4vw,3.25rem);font-weight:720}.text-gradient{background:linear-gradient(110deg, var(--text-primary) 10%, #e8d8c7 48%, var(--accent-warm) 105%);color:#0000;-webkit-background-clip:text;background-clip:text}.btn,.btn-icon,.topbar__user button,.topbar__auth-link{border-color:#ffffff21;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffff1f}.btn:after,.btn-icon:after,.topbar__user button:after,.topbar__auth-link:after{content:"";pointer-events:none;opacity:0;background:linear-gradient(90deg,#0000,#ffffff57,#0000);width:46%;transition:left .52s cubic-bezier(.22,1,.36,1),opacity .18s;position:absolute;inset:-40% auto -40% -70%;transform:skew(-18deg)}.btn-primary{background:linear-gradient(145deg, #ef7b48, var(--accent-primary) 58%, #c74620);border-color:#f4c4304d;box-shadow:inset 0 1px #ffffff57,0 12px 28px #e85d2b40}.btn-primary:hover{background:linear-gradient(145deg, #f18a58, var(--accent-primary-hover) 58%, #b83c1b);box-shadow:inset 0 1px #ffffff61,0 16px 34px #e85d2b5c}.btn-secondary,.btn-icon,.topbar__user button,.topbar__auth-link{-webkit-backdrop-filter:blur(18px);background:#fff1}.btn-secondary:hover,.btn-icon:hover,.topbar__user button:hover,.topbar__auth-link:hover{background:#ffffff1c;border-color:#ffffff3b}:where(button,.btn,.btn-icon,.nav-item,.side-rail__item,.side-rail__user,.topbar__auth-link,.theme-toggle__option,.meal-planner__chip,.quantity-stepper__btn,.ai-search-tool,.starter-button,.tool-button,.btn-ghost,.btn-add-manual,.btn-restore-ingredient,.btn-restore-all){transform-origin:50%;-webkit-tap-highlight-color:transparent;transition:transform .18s cubic-bezier(.22,1,.36,1),box-shadow .22s,border-color .18s,background-color .18s,color .18s,opacity .18s}@media (hover:hover) and (pointer:fine){:where(button,.btn,.btn-icon,.nav-item,.side-rail__item,.side-rail__user,.topbar__auth-link,.theme-toggle__option,.quantity-stepper__btn,.ai-search-tool,.starter-button,.tool-button,.btn-ghost,.btn-add-manual,.btn-restore-ingredient,.btn-restore-all):not(:disabled):hover{transform:translateY(-2px)scale(1.015)}:where(button,.btn,.btn-icon,.nav-item,.side-rail__item,.side-rail__user,.topbar__auth-link):not(:disabled):hover svg{transform:translateY(-1px)scale(1.08)}.btn:not(:disabled):hover:after,.btn-icon:not(:disabled):hover:after,.topbar__user button:not(:disabled):hover:after,.topbar__auth-link:hover:after{opacity:.88;left:125%}}:where(button,.btn,.btn-icon,.nav-item,.side-rail__item,.side-rail__user,.topbar__auth-link,.theme-toggle__option,.quantity-stepper__btn,.ai-search-tool,.starter-button,.tool-button,.btn-ghost,.btn-add-manual,.btn-restore-ingredient,.btn-restore-all):not(:disabled):active{transition-duration:80ms;transform:translateY(1px)scale(.965)}:where(button,.btn,.btn-icon,.nav-item,.side-rail__item,.side-rail__user,.topbar__auth-link,.theme-toggle__option,.quantity-stepper__btn,.ai-search-tool,.starter-button,.tool-button,.btn-ghost,.btn-add-manual,.btn-restore-ingredient,.btn-restore-all):focus-visible{outline-offset:3px;outline:2px solid #f4c430e0;box-shadow:0 0 0 6px #e85d2b29}:where(button,.btn,.btn-icon) svg{transition:transform .22s cubic-bezier(.22,1,.36,1),opacity .18s}:where(button,.btn,.btn-icon):disabled{box-shadow:none;transform:none!important}.btn-primary:not(:disabled){animation:3.8s ease-in-out infinite primary-button-glow}.btn-primary:not(:disabled):hover{animation-play-state:paused}.btn:not(:disabled):active,.btn-icon:not(:disabled):active{transform:translateY(1px)scale(.965)}@keyframes primary-button-glow{0%,to{box-shadow:inset 0 1px #ffffff57,0 12px 28px #e85d2b3d}50%{box-shadow:inset 0 1px #ffffff6b,0 16px 36px #e85d2b66}}.center-nav-item>div{animation:3.4s ease-in-out infinite center-action-float}@media (hover:hover) and (pointer:fine){.center-nav-item:not(:disabled):hover{transform:translateY(-16px)scale(1.015)}}.center-nav-item:not(:disabled):active{transform:translateY(-13px)scale(.965)}@keyframes center-action-float{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-3px)scale(1.035)}}input,textarea,select,.home-mobile-search,.theme-toggle,.share-modal__input{-webkit-backdrop-filter:blur(18px);box-shadow:inset 0 1px #ffffff0d;background:#14130f7a!important;border-color:#ffffff1c!important}input:focus,textarea:focus,select:focus{outline:none;box-shadow:0 0 0 4px #e85d2b1f;border-color:#e85d2bb3!important}.home-mobile-search input,.home-mobile-search input:focus{-webkit-backdrop-filter:none;box-shadow:none!important;background:0 0!important;border:0!important;padding:0!important}.filters-section{border-radius:26px;padding:1.15rem 1.25rem}.filter-group label{color:#d3dbeb;letter-spacing:.08em}.bottom-nav{height:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom,0px));border:1px solid #ffffff24;border-radius:24px;bottom:10px;left:10px;right:10px;box-shadow:inset 0 1px #ffffff29,0 18px 46px #0004126b}.center-nav-item{cursor:pointer;transform:translateY(-14px);background:0 0!important;border:none!important}.center-nav-item>div{border:1px solid #f4c4305c;border-radius:999px;place-items:center;margin-bottom:4px;padding:14px;display:grid;background:linear-gradient(145deg, #ef8250, var(--accent-primary) 60%, #b94020)!important;box-shadow:inset 0 1px #ffffff6b,0 14px 30px #e85d2b61!important}.modal-overlay,.compare-modal,.share-modal__scrim,.ai-search-modal__scrim{-webkit-backdrop-filter:blur(14px)saturate(130%);background:#08070585}.auth-page{background:0 0}.auth-page:before,.auth-page:after{display:none}.auth-form{background:linear-gradient(145deg,#ffffff1f,#ffffff06),#1e1c18a8;border-radius:30px}:root[data-theme=light] input,:root[data-theme=light] textarea,:root[data-theme=light] select,:root[data-theme=light] .home-mobile-search,:root[data-theme=light] .theme-toggle,:root[data-theme=light] .share-modal__input{box-shadow:inset 0 1px #ffffffeb,0 6px 18px #50341f0a;background:#fffcf7b3!important;border-color:#5c453326!important}:root[data-theme=light] body{background:#eeeae3}:root[data-theme=light] body:after{background:radial-gradient(circle at 14% 30%,#2d5f3f14,#0000 36rem),radial-gradient(circle at 84% 74%,#e85d2b17,#0000 38rem),#fffcf714}:root[data-theme=light] .glass-card,:root[data-theme=light] .filters-section,:root[data-theme=light] .meal-planner,:root[data-theme=light] .settings-card,:root[data-theme=light] .share-modal__panel,:root[data-theme=light] .compare-modal__panel,:root[data-theme=light] .share-recipe,:root[data-theme=light] .share-plan,:root[data-theme=light] .share-cart-menu,:root[data-theme=light] .auth-form,:root[data-theme=light] .modal-container,:root[data-theme=light] .ai-search-modal__panel{background:linear-gradient(145deg, #ffffffe0, #fffaf45c 58%), var(--surface);box-shadow:inset 0 1px 0 #fffffff5, inset 0 -1px 0 #5c45330d, var(--shadow-glass);border-color:#5c453326}:root[data-theme=light] .side-rail{background:linear-gradient(160deg,#ffffffe0,#0000 40%),#fffcf7ad;border-color:#5c453326;box-shadow:inset 0 1px #fffffff5,0 24px 70px #50341f24}:root[data-theme=light] .side-rail__brand{border-bottom-color:#5c45331a}:root[data-theme=light] .side-rail__item:hover,:root[data-theme=light] .side-rail__user:hover{background:#ffffff8a;border-color:#5c45331a}:root[data-theme=light] .side-rail__item.active,:root[data-theme=light] .side-rail__user.active{background:linear-gradient(135deg,#e85d2b26,#f4c43012);border-color:#e85d2b47;box-shadow:inset 0 1px #ffffffe0}:root[data-theme=light] .topbar,:root[data-theme=light] .bottom-nav{background:linear-gradient(145deg, #ffffffd1, transparent 52%), var(--topbar-bg);border-color:#5c453326;box-shadow:inset 0 1px #fffffff5,0 18px 48px #50341f21}:root[data-theme=light] .topbar__search,:root[data-theme=light] .btn-secondary,:root[data-theme=light] .btn-icon,:root[data-theme=light] .topbar__user button,:root[data-theme=light] .topbar__auth-link{background:#ffffff85;border-color:#5c453321;box-shadow:inset 0 1px #ffffffe6}:root[data-theme=light] .topbar__search:focus-within,:root[data-theme=light] .home-mobile-search:focus-within{background:#ffffffbd}:root[data-theme=light] .btn-secondary:hover,:root[data-theme=light] .btn-icon:hover,:root[data-theme=light] .topbar__user button:hover,:root[data-theme=light] .topbar__auth-link:hover{background:#ffffffc7;border-color:#e85d2b4d}:root[data-theme=light] .text-gradient{background:linear-gradient(110deg,#211c18 8%,#85513a 56%,#b18718 108%);color:#0000;-webkit-background-clip:text;background-clip:text}:root[data-theme=light] .filter-group label{color:var(--text-secondary)}:root[data-theme=light] .theme-toggle__option.active{background:#ffffffc2;border-color:#5c453324}:root[data-theme=light] .modal-overlay,:root[data-theme=light] .compare-modal,:root[data-theme=light] .share-modal__scrim,:root[data-theme=light] .ai-search-modal__scrim{-webkit-backdrop-filter:blur(18px)saturate(115%);background:#4d392b4d}:root[data-theme=light] .modal-container,:root[data-theme=light] .share-modal__panel,:root[data-theme=light] .compare-modal__panel,:root[data-theme=light] .ai-search-modal__panel{-webkit-backdrop-filter:blur(34px)saturate(130%);background:linear-gradient(145deg,#fffffffa,#fffaf4e6),#fffcf7f0}:root[data-theme=light] .auth-form{background:linear-gradient(145deg,#ffffffe6,#fffaf46b),#fffcf7b3}:root[data-theme=light] ::-webkit-scrollbar-thumb{background:#5c453338 padding-box padding-box}::-webkit-scrollbar-thumb{background:#ffffff2b padding-box padding-box;border-color:#0000}@media (max-width:899px){:root{--app-background-image:url(/images/backgrounds/cookbook-mobile.webp)}:root[data-theme=light]{--app-background-image:url(/images/backgrounds/cookbook-mobile-light.webp)}body:before{background-position:top;inset:-2.5%}.topbar{width:calc(100% - 1rem);margin-top:8px;top:8px}.container{padding-top:2rem}.home-hero{padding:.4rem .35rem}}@media (max-width:520px){.auth-page{padding:18px}.auth-form{width:min(100%,100vw - 36px);max-width:calc(100vw - 36px);padding:28px 22px}}@media (prefers-reduced-motion:reduce){body,body:before,body:after,.modal-overlay,.compare-modal,.share-modal__scrim,.ai-search-modal__scrim,.btn-primary:not(:disabled),.center-nav-item>div{animation:none}:where(button,.btn,.btn-icon,.nav-item,.side-rail__item,.side-rail__user,.topbar__auth-link){transition-duration:.01ms!important}.btn:after,.btn-icon:after,.topbar__user button:after,.topbar__auth-link:after{display:none}}.home-mobile-search input,.home-mobile-search input:focus,:root[data-theme=light] .home-mobile-search input,:root[data-theme=light] .home-mobile-search input:focus{-webkit-backdrop-filter:none;box-shadow:none!important;background:0 0!important;border:0!important;padding:0!important}.recipe-share-toggle{top:18px}
