:root{--bg:#faf6f0;--bg-raised:#ffffff;--bg-sunken:#f1ebe0;--bg-inset:#f6f0e3;--ink:#1a1410;--ink-soft:#5c4a3d;--ink-faint:#8b7563;--line:#e5dccd;--line-soft:#efe8d9;--accent:#b54a25;--accent-ink:#7a2f15;--accent-tint:#f7e8df;--accent-tint-strong:#f1d6c5;--accent-2:#6b5b8a;--accent-2-tint:#ece8f0;--success:#5a7a3f;--success-tint:#eaf0e1;--warn:#c4871f;--warn-tint:#f7ecd6;--radius:14px;--radius-sm:10px;--radius-lg:22px;--radius-xl:28px;--shadow:0 1px 0 rgba(122,86,50,.03),0 2px 6px rgba(122,86,50,.04);--shadow-md:0 1px 0 rgba(122,86,50,.03),0 2px 8px rgba(122,86,50,.05);--shadow-lg:0 2px 8px rgba(26,20,16,.06),0 24px 48px rgba(26,20,16,.1);--serif:"Fraunces",Georgia,serif;--sans:"Inter Tight",-apple-system,BlinkMacSystemFont,sans-serif;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px);--bg-elevated:var(--bg-raised);--accent-bg:var(--accent-tint);--green:var(--success);--cook-bg:#1a1410;--cook-surface:#2a221d;--cook-surface-b:#352a23;--cook-fg:#faf6f0;--cook-fg-soft:#c5b8a7;--cook-fg-faint:#8b7563;--cook-accent:#e08a5a}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html,body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased}body{min-height:100vh;min-height:100dvh;padding-top:var(--safe-top);padding-bottom:calc(72px + var(--safe-bottom));overscroll-behavior-y:none}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}input:focus,textarea:focus,select:focus,button:focus{outline:none}::-moz-selection{background:var(--accent);color:var(--bg)}::selection{background:var(--accent);color:var(--bg)}.app{max-width:720px;margin:0 auto;padding:0 20px}.header{padding:28px 0 20px;display:flex;align-items:baseline;justify-content:space-between;gap:16px}.header h1{font-family:var(--serif);font-weight:400;font-size:34px;letter-spacing:-.02em;line-height:1;font-variation-settings:"opsz" 144}.header h1 em{font-style:italic;color:var(--accent);font-weight:300}.header-sub{font-size:12px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.12em;font-weight:500}.header-right{display:flex;align-items:center;gap:12px}.nav{position:fixed;bottom:0;left:0;right:0;background:#faf6f0eb;backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);border-top:1px solid var(--line-soft);padding:8px 12px calc(10px + var(--safe-bottom));z-index:100}.nav-grid{display:grid;grid-template-columns:repeat(5,1fr);align-items:end;max-width:720px;margin:0 auto}.nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:4px 0;color:var(--ink-faint);background:none;border:none;cursor:pointer}.nav-item.active{color:var(--accent)}.nav-icon{width:22px;height:22px;stroke-width:1.6}.nav-item.active .nav-icon{stroke-width:1.9}.nav-label{font-size:10px;font-weight:500;letter-spacing:.01em}.nav-item--menu{display:flex;justify-content:center;position:relative}.nav-menu-btn{width:50px;height:50px;border-radius:25px;background:var(--ink);color:var(--bg);display:flex;align-items:center;justify-content:center;margin-top:-16px;box-shadow:0 4px 14px #1a141040,0 1px #ffffff0d inset;border:none;cursor:pointer;position:relative;flex-shrink:0}.nav-menu-dot{position:absolute;top:2px;right:2px;width:7px;height:7px;border-radius:50%;background:var(--accent);border:1.5px solid var(--bg)}.section{margin-bottom:22px;background:var(--bg-elevated);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}.section-label{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--accent);margin-bottom:16px;display:flex;align-items:center;gap:10px;font-weight:400}.section-label:after{content:"";flex:1;height:1px;background:var(--line)}.stepper{display:flex;align-items:center;justify-content:space-between;background:var(--bg-sunken);border-radius:var(--radius-sm);padding:6px}.stepper-btn{width:38px;height:38px;border-radius:8px;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--ink);transition:all .1s;box-shadow:0 1px 2px #0000000a}.stepper-btn:active{transform:scale(.94)}.stepper-btn:disabled{opacity:.3}.stepper-value{font-family:var(--serif);font-size:22px;font-weight:500}.stepper-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:16px}.stepper-row:not(:last-child){border-bottom:1px solid var(--line-soft)}.stepper-label{font-size:15px;color:var(--ink-soft);font-weight:500}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{padding:9px 14px;background:var(--bg-sunken);border:1px solid transparent;border-radius:100px;font-size:13px;font-weight:500;color:var(--ink-soft);transition:all .15s}.chip:active{transform:scale(.96)}.chip.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}.chip-accent.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}.generate-btn{width:100%;padding:18px;background:var(--ink);color:var(--bg);border-radius:var(--radius);font-family:var(--serif);font-size:17px;font-weight:500;letter-spacing:.01em;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .15s;box-shadow:var(--shadow)}.generate-btn:active{transform:scale(.99)}.generate-btn:disabled{opacity:.5}.generate-btn em{font-style:italic;font-weight:300}.recipe-card{background:var(--bg-raised);border:1px solid var(--line-soft);border-radius:var(--radius);margin-bottom:14px;box-shadow:var(--shadow-md);transition:transform .15s;cursor:pointer;position:relative;overflow:hidden}.recipe-card:active{transform:scale(.99)}.recipe-card-hero{position:relative;height:196px;background:var(--bg-sunken);overflow:hidden}.recipe-card-hero-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.recipe-card-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--accent-tint-strong) 0%,var(--bg-sunken) 100%)}.recipe-card-fav-btn{position:absolute;top:12px;right:12px;width:38px;height:38px;border-radius:50%;background:#ffffffd9;backdrop-filter:blur(8px) saturate(150%);-webkit-backdrop-filter:blur(8px) saturate(150%);box-shadow:0 1px 3px #0000001f;border:none;cursor:pointer;color:var(--ink);display:flex;align-items:center;justify-content:center}.recipe-card-fav-btn svg{width:18px;height:18px;stroke-width:1.8}.recipe-card-fav-btn.active{color:var(--accent)}.recipe-card-fav-btn.active svg{stroke:var(--accent);fill:var(--accent)}.recipe-card-tag-overlay{position:absolute;left:12px;bottom:12px;display:flex;gap:6px;flex-wrap:wrap;max-width:calc(100% - 74px)}.recipe-card-tag{font-family:var(--sans);font-size:11px;line-height:14px;font-weight:500;color:var(--ink);background:#ffffffeb;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:4px 9px;border-radius:999px;white-space:nowrap}.recipe-card-body{padding:14px 16px}.recipe-card-title{font-family:var(--serif);font-size:20px;line-height:24px;font-weight:500;letter-spacing:-.01em;color:var(--ink);margin:0 0 8px}.recipe-card-meta{display:flex;gap:14px;flex-wrap:wrap;font-family:var(--sans);font-size:13px;line-height:17px;color:var(--ink-soft)}.recipe-card-meta-item{display:flex;align-items:center;gap:5px}.recipe-card-meta svg{width:13px;height:13px;stroke-width:1.7}.recipe-card-regime{display:inline-block;font-family:var(--sans);font-size:11.5px;line-height:14px;font-weight:500;background:var(--success-tint);color:var(--success);padding:4px 9px;border-radius:999px;margin-top:10px}.recipe-card-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;padding-top:12px;border-top:1px solid var(--line-soft)}.recipe-card-footer-stats{display:flex;align-items:center;gap:14px}.recipe-card-score{display:flex;align-items:center;gap:4px;font-family:var(--sans);font-size:13px;font-weight:500;color:var(--ink)}.recipe-card-score svg{width:13px;height:13px;color:var(--warn)}.recipe-card-score-total{color:var(--ink-faint);font-weight:400}.recipe-card-cooked{font-family:var(--sans);font-size:13px;color:var(--ink-soft)}.recipe-card-cooked strong{color:var(--ink);font-weight:600}.recipe-card-regen{display:flex;align-items:center;gap:4px;background:none;border:none;color:var(--ink-faint);cursor:pointer;padding:4px 6px;font-family:var(--sans);font-size:13px}.recipe-card-regen:disabled{opacity:.6;cursor:default}.recipe-card-regen svg{width:14px;height:14px;stroke-width:1.6}.recipe-card-compact{width:160px;flex-shrink:0;cursor:pointer}.recipe-card-compact-photo{position:relative;height:108px;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-sunken)}.recipe-card-compact-title{font-family:var(--serif);font-size:14px;line-height:17px;font-weight:400;color:var(--ink);letter-spacing:-.005em;margin:8px 0 4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.recipe-card-compact-meta{font-family:var(--sans);font-size:11.5px;line-height:14px;color:var(--ink-faint)}.recipe-card-skeleton{background:var(--bg-raised);border:1px solid var(--line-soft);border-radius:var(--radius);margin-bottom:14px;overflow:hidden;box-shadow:var(--shadow-md)}.recipe-card-skeleton-hero{height:196px}.recipe-card-skeleton-line{height:22px;border-radius:6px;margin-bottom:8px}.recipe-card-skeleton-meta{display:flex;gap:10px;margin-top:14px}.recipe-card-skeleton-block{height:14px;border-radius:4px}.tag{font-size:10px;padding:3px 8px;border-radius:4px;background:var(--bg-sunken);color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.tag-accent{background:var(--accent-bg);color:var(--accent)}.icon-btn{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}.icon-btn:active{background:var(--bg-sunken)}.icon-btn svg{width:20px;height:20px;stroke-width:1.5}.icon-btn.fav-active{color:var(--accent)}.icon-btn.fav-active svg{fill:var(--accent)}.detail-back{display:flex;align-items:center;gap:6px;padding:10px 0;color:var(--ink-soft);font-size:14px;font-weight:500;margin-bottom:8px}.detail-back svg{width:18px;height:18px;stroke-width:2}.detail-hero{padding:0 4px 24px}.detail-hero-eyebrow{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--accent);margin-bottom:8px}.detail-meal-type{display:inline-block;padding:3px 8px;font-family:var(--sans);font-style:normal;font-size:.75rem;border-radius:var(--radius-lg);background:var(--bg-sunken);color:var(--ink-faint);margin-left:8px}.card-meal-type{font-size:.75rem;color:var(--ink-faint)}.detail-hero h2{font-family:var(--serif);font-size:34px;line-height:1.1;font-weight:500;letter-spacing:-.02em;margin-bottom:14px;font-variation-settings:"opsz" 144}.detail-hero-meta{display:flex;gap:18px;flex-wrap:wrap;font-size:13px;color:var(--ink-soft);align-items:center}.detail-hero-meta span{display:flex;align-items:center;gap:5px}.detail-hero-meta svg{width:15px;height:15px;stroke-width:1.6}.nutrition{display:grid;grid-template-columns:repeat(5,1fr);gap:0;background:var(--bg-elevated);border-radius:var(--radius);padding:18px 8px;margin-bottom:22px;box-shadow:var(--shadow)}.nutrition-cell{text-align:center;padding:0 4px;position:relative}.nutrition-cell:not(:last-child):after{content:"";position:absolute;right:0;top:15%;bottom:15%;width:1px;background:var(--line)}.nutrition-value{font-family:var(--serif);font-size:19px;font-weight:500;line-height:1;margin-bottom:4px}.nutrition-label{font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint);font-weight:600}.servings-control{display:flex;align-items:center;justify-content:space-between;background:var(--bg-elevated);border-radius:var(--radius);padding:14px 18px;margin-bottom:22px;box-shadow:var(--shadow)}.servings-control-label{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--ink-soft)}.unit-toggle{display:flex;background:var(--bg-sunken);border-radius:100px;padding:3px;margin-bottom:22px}.unit-toggle button{flex:1;padding:10px;border-radius:100px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);transition:all .15s}.unit-toggle button.active{background:var(--bg-elevated);color:var(--ink);box-shadow:0 1px 3px #0000000f}.ingredient-list{background:var(--bg-elevated);border-radius:var(--radius);padding:8px 20px;margin-bottom:22px;box-shadow:var(--shadow)}.ingredient-row{display:flex;justify-content:space-between;align-items:baseline;padding:14px 0;border-bottom:1px dashed var(--line-soft);gap:12px}.ingredient-row:last-child{border-bottom:none}.ingredient-name{font-size:15px;flex:1}.ingredient-qty{font-family:var(--serif);font-size:15px;font-weight:500;color:var(--accent);white-space:nowrap}.instruction-list{background:var(--bg-elevated);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);margin-bottom:22px}.instruction-row{display:flex;gap:18px;padding:14px 0}.instruction-row:not(:last-child){border-bottom:1px solid var(--line-soft)}.instruction-num{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--accent);line-height:1;flex-shrink:0;min-width:22px}.instruction-text{font-size:15px;line-height:1.55;color:var(--ink-soft)}.recipe-notes{background:var(--accent-bg);border-radius:var(--radius);padding:18px 20px;margin-bottom:22px}.recipe-notes-label{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--accent);margin-bottom:6px}.recipe-notes-text{font-size:14px;line-height:1.5;color:var(--ink-soft)}.empty{text-align:center;padding:60px 20px}.empty-icon{font-family:var(--serif);font-style:italic;font-size:60px;color:var(--line);margin-bottom:12px;line-height:1}.empty-title{font-family:var(--serif);font-size:19px;margin-bottom:6px;font-weight:500}.empty-text{font-size:14px;color:var(--ink-faint);max-width:280px;margin:0 auto}.loading{text-align:center;padding:60px 20px}.loading-spinner{width:30px;height:30px;border:2px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 18px}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--ink-soft)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.type-display{font-family:var(--serif);font-size:36px;line-height:40px;letter-spacing:-.02em;font-weight:400}.type-h1{font-family:var(--serif);font-size:28px;line-height:32px;letter-spacing:-.015em;font-weight:400}.type-h2{font-family:var(--serif);font-size:22px;line-height:26px;letter-spacing:-.01em;font-weight:400}.type-h3{font-family:var(--sans);font-size:17px;line-height:22px;letter-spacing:-.005em;font-weight:600}.type-body{font-family:var(--sans);font-size:15px;line-height:21px;font-weight:400}.type-body-md{font-family:var(--sans);font-size:15px;line-height:21px;font-weight:500}.type-caption{font-family:var(--sans);font-size:13px;line-height:17px;font-weight:400}.type-caption-md{font-family:var(--sans);font-size:13px;line-height:17px;font-weight:500}.type-overline{font-family:var(--sans);font-size:11px;line-height:14px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.type-serif-label{font-family:var(--serif);font-size:13px;line-height:16px;letter-spacing:.04em;font-weight:400;font-style:italic}.spotlight-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:#00000080}.spotlight-ring{position:absolute;width:66px;height:66px;border-radius:33px;border:2px solid var(--accent);left:50%;transform:translate(-50%);bottom:calc(var(--safe-bottom) + 26px);animation:pulseRing 2s ease-in-out infinite}@keyframes pulseRing{0%,to{transform:translate(-50%) scale(1);opacity:1}50%{transform:translate(-50%) scale(1.08);opacity:.7}}.spotlight-tooltip{position:absolute;left:50%;transform:translate(-50%);bottom:calc(var(--safe-bottom) + 116px);width:280px;background:var(--bg-raised);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-lg);animation:fadeInUp .4s ease-out}.spotlight-tooltip:after{content:"";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);border-left:8px solid transparent;border-right:8px solid transparent;border-top:8px solid var(--bg-raised)}.spotlight-eyebrow{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--accent);margin-bottom:4px}.spotlight-title{font-family:var(--serif);font-size:18px;font-weight:400;color:var(--ink);margin-bottom:12px}.spotlight-list{list-style:none;margin:0 0 14px;padding:0;display:flex;flex-direction:column;gap:6px}.spotlight-list-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-soft)}.spotlight-list-icon{width:14px;height:14px;stroke-width:1.6;flex-shrink:0;color:var(--accent)}.spotlight-cta{width:100%;padding:12px;background:var(--ink);color:var(--bg);border-radius:var(--radius-sm);font-size:14px;font-weight:500;cursor:pointer;border:none}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{transform:translateY(120%)}to{transform:translateY(0)}}@keyframes shimmer{to{transform:translate(100%)}}.shimmer{position:relative;overflow:hidden;background:var(--bg-sunken)}.shimmer:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(100deg,transparent 20%,rgba(255,255,255,.55) 50%,transparent 80%);transform:translate(-100%);animation:shimmer 1.5s ease-in-out infinite}.btn-primary{flex:1;padding:14px;background:var(--ink);color:var(--bg);border-radius:var(--radius-sm);font-weight:600;font-size:14px}.btn-secondary{flex:1;padding:14px;background:var(--bg-sunken);color:var(--ink);border-radius:var(--radius-sm);font-weight:600;font-size:14px}.btn-primary:disabled,.btn-secondary:disabled{opacity:.5}.settings-row{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:1px solid var(--line-soft);gap:12px}.settings-row:last-child{border-bottom:none}.settings-label{font-size:15px}.settings-sublabel{font-size:12px;color:var(--ink-faint);margin-top:2px}.settings-action{padding:8px 14px;background:var(--bg-sunken);border-radius:8px;font-size:13px;font-weight:500;color:var(--ink-soft);white-space:nowrap}.settings-action:active{background:var(--line)}.settings-action.danger{color:var(--accent)}.settings-action.primary{background:var(--ink);color:var(--bg)}.shopping-banner{background:var(--accent-tint);color:var(--accent-ink);padding:10px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;margin-bottom:14px;border-left:3px solid var(--accent)}.shopping-filters{background:var(--bg-elevated);border-radius:var(--radius);padding:16px 20px;margin-bottom:16px;box-shadow:var(--shadow)}.shopping-source-toggle{display:flex;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;margin-bottom:16px;background:var(--bg-elevated)}.shopping-source-btn{flex:1;padding:10px 8px;font-size:.85rem;text-align:center;color:var(--ink-soft);background:var(--bg-elevated);border-right:1px solid var(--line);font-weight:400;transition:all .15s}.shopping-source-btn:last-child{border-right:none}.shopping-source-btn.active{background:var(--accent);color:var(--bg);font-weight:500}.shopping-filter-label{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--accent);margin-bottom:12px}.shopping-filter-row{display:flex;align-items:center;gap:10px;padding:8px 0}.checkbox{width:20px;height:20px;border:1.5px solid var(--ink-faint);border-radius:5px;display:flex;align-items:center;justify-content:center;transition:all .1s;flex-shrink:0}.checkbox.checked{background:var(--ink);border-color:var(--ink)}.checkbox.checked svg{width:13px;height:13px;color:var(--bg)}.shopping-recipe-name{font-size:14px;flex:1}.shopping-list{background:var(--bg-elevated);border-radius:var(--radius);padding:8px 20px;box-shadow:var(--shadow)}.shopping-row{display:flex;justify-content:space-between;align-items:baseline;padding:13px 0;border-bottom:1px dashed var(--line-soft);gap:12px}.shopping-row:last-child{border-bottom:none}.shopping-row.checked .shopping-name{text-decoration:line-through;color:var(--ink-faint)}.shopping-name{font-size:15px;flex:1}.shopping-qty{font-family:var(--serif);font-size:14px;font-weight:500;color:var(--accent);white-space:nowrap}.toast{position:fixed;bottom:calc(85px + var(--safe-bottom));left:50%;transform:translate(-50%);background:var(--ink);color:var(--bg);padding:12px 20px;border-radius:100px;font-size:13px;font-weight:500;z-index:300;box-shadow:var(--shadow-lg);animation:toastIn .3s;max-width:90vw}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,10px)}}.error-banner{background:var(--accent-bg);color:var(--accent);padding:12px 16px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:16px;border-left:3px solid var(--accent)}.recipe-actions-bar{display:flex;gap:8px;margin-top:14px;padding-top:14px;border-top:1px solid var(--line-soft)}.recipe-actions-bar button{flex:1;padding:10px;background:var(--bg-sunken);border-radius:8px;font-size:12px;font-weight:500;color:var(--ink-soft);display:flex;align-items:center;justify-content:center;gap:6px}.recipe-actions-bar button:active{background:var(--line)}.recipe-actions-bar svg{width:14px;height:14px;stroke-width:1.8}.file-input{display:none}.auth-loading{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg)}.login-card{width:100%;max-width:400px;text-align:center}.login-card h1{font-family:var(--serif);font-weight:400;font-size:42px;letter-spacing:-.02em;line-height:1;font-variation-settings:"opsz" 144;margin-bottom:12px}.login-card h1 em{font-style:italic;color:var(--accent);font-weight:300}.login-subtitle{font-size:14px;color:var(--ink-soft);margin-bottom:28px}.login-input{width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-elevated);color:var(--ink);font-size:16px;margin-bottom:14px;transition:border-color .15s}.login-input:focus{border-color:var(--accent)}.login-submit{width:100%;padding:14px}.login-error{margin-top:14px;color:var(--warn);font-size:13px;line-height:1.45}.login-retry{margin-top:18px;background:none;color:var(--accent);font-size:14px;font-weight:500;text-decoration:underline}.settings-action.warn{color:var(--warn)}.settings-key-edit{display:flex;flex-direction:column;gap:12px;padding:8px 0}.settings-key-edit .login-input{margin-bottom:0}.settings-key-actions{display:flex;justify-content:flex-end;gap:8px}.add-recipe-btn{width:100%;padding:14px;margin-bottom:18px;border:1px dashed var(--accent);border-radius:var(--radius);background:transparent;color:var(--accent);font-family:var(--serif);font-style:italic;font-size:15px;text-align:center;transition:background .15s}.add-recipe-btn:active{background:var(--accent-bg)}.create-field{margin-bottom:14px}.create-field label{display:block;font-size:12px;color:var(--ink-faint);margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}.create-input{width:100%;padding:12px 14px;background:var(--bg-sunken);border:1px solid transparent;border-radius:var(--radius-sm);font-size:14px;color:var(--ink);transition:border-color .15s;font-family:inherit}.create-input:focus{border-color:var(--accent)}.create-input-error{border-color:var(--warn)}textarea.create-input{resize:vertical;min-height:64px;line-height:1.4}.create-error-text{font-size:12px;color:var(--warn);margin-bottom:10px}.create-ingredient-row{display:grid;grid-template-columns:1fr 70px 90px 28px;gap:6px;margin-bottom:8px;align-items:center}.create-ingredient-row .create-input{padding:10px}.create-instruction-row{display:flex;align-items:flex-start;gap:8px;margin-bottom:8px}.create-instruction-num{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--accent);line-height:1;padding-top:14px;min-width:22px;flex-shrink:0}.create-instruction-row .create-input{flex:1}.create-row-remove{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:transparent;color:var(--ink-faint);font-size:18px;line-height:1;padding:0;flex-shrink:0;transition:background .15s}.create-row-remove:active{background:var(--bg-sunken)}.create-row-remove:disabled{opacity:.3}.create-add-row{margin-top:6px;padding:10px 14px;background:var(--bg-sunken);color:var(--ink-soft);border-radius:var(--radius-sm);font-size:13px;font-weight:500;transition:background .15s}.create-add-row:active{background:var(--line)}.enhance-btn{width:100%;padding:14px;margin-bottom:18px;border:1px solid var(--accent);border-radius:var(--radius);background:var(--accent-bg);color:var(--accent);font-family:var(--serif);font-style:italic;font-size:15px;display:flex;align-items:center;justify-content:center;gap:10px;transition:opacity .15s}.enhance-btn:disabled{opacity:.6}.enhance-btn svg{width:18px;height:18px;stroke-width:1.5}.enhanced-section{margin-bottom:22px}.create-favorite-toggle{display:flex;align-items:center;gap:10px;padding:14px 16px;margin-bottom:18px;background:var(--bg-elevated);border-radius:var(--radius-sm);box-shadow:var(--shadow);font-size:14px;color:var(--ink-soft);cursor:pointer}.create-favorite-toggle input{width:18px;height:18px;accent-color:var(--accent)}.create-sublabel{font-size:12px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px}.create-loading{text-align:center;padding:40px 0}.create-skeletons{margin-top:24px;display:flex;flex-direction:column;gap:14px}.create-modify-bar{width:100%;display:flex;align-items:center;gap:10px;padding:14px 18px;background:var(--bg-raised);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:16px;text-align:left;border:none;cursor:pointer}.create-modify-bar:active{background:var(--bg-sunken)}.create-modify-label{font-size:14px;font-weight:500;color:var(--ink);flex-shrink:0}.create-modify-summary{flex:1;font-size:12px;color:var(--ink-faint);text-align:right}.create-modify-arrow{font-size:14px;color:var(--ink-faint);flex-shrink:0}.create-form-collapsed{background:var(--bg-inset);border-radius:var(--radius);padding:16px;margin-bottom:16px}.create-results-action-bar{display:flex;flex-direction:column;gap:10px;margin-top:24px;padding-top:20px;border-top:1px solid var(--line-soft);margin-bottom:24px}.create-results-btn{width:100%;padding:14px;border-radius:var(--radius);font-size:15px;font-weight:500;cursor:pointer;border:none}.create-results-btn--primary{background:var(--ink);color:var(--bg)}.create-results-btn--secondary{background:transparent;color:var(--ink);border:1px solid var(--line)}.create-results-btn--ghost{background:transparent;color:var(--ink-faint);font-size:14px;padding:10px}.create-actions{display:flex;gap:10px;margin-bottom:22px}.create-actions .btn-primary,.create-actions .btn-secondary{padding:14px}.exclusion-input-row{display:flex;gap:8px;margin-bottom:14px}.exclusion-input-row input{flex:1;min-width:0;padding:12px 14px;background:var(--bg-sunken);border:1px solid transparent;border-radius:var(--radius-sm);font-size:14px;color:var(--ink);transition:border-color .15s}.exclusion-input-row input:focus{border-color:var(--accent)}.exclusion-input-row button{padding:12px 18px;border-radius:var(--radius-sm);background:var(--ink);color:var(--bg);font-size:13px;font-weight:600;white-space:nowrap;transition:opacity .15s}.exclusion-input-row button:disabled{opacity:.4}.exclusion-tags{display:flex;flex-wrap:wrap;gap:8px}.exclusion-tag{display:inline-flex;align-items:center;gap:8px;padding:6px 6px 6px 12px;border-radius:100px;background:var(--bg-sunken);color:var(--ink-soft);font-size:13px;font-weight:500}.exclusion-tag button{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:transparent;color:var(--ink-faint);font-size:16px;line-height:1;padding:0;transition:background .15s}.exclusion-tag button:active{background:var(--line)}.exclusion-summary{display:flex;align-items:center;gap:10px;padding:14px 16px;margin-bottom:18px;border-radius:var(--radius);background:var(--accent-bg);color:var(--accent);font-size:13px;font-weight:500;cursor:pointer;transition:transform .1s}.exclusion-summary:active{transform:scale(.99)}.exclusion-summary-text{flex:1}.exclusion-summary-arrow{font-family:var(--serif);font-style:italic;font-size:18px;line-height:1}.score-row{display:flex;align-items:center;gap:12px;padding:10px 4px 6px;margin-bottom:8px}.score-label{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--accent);min-width:36px}.score-slider{flex:1;min-width:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;border-radius:2px;background:var(--line);outline:none;padding:0;margin:0;cursor:pointer}.score-slider::-webkit-slider-runnable-track{height:4px;border-radius:2px;background:transparent}.score-slider::-moz-range-track{height:4px;border-radius:2px;background:var(--line)}.score-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;background:var(--accent);border:2px solid var(--bg-elevated);box-shadow:0 1px 3px #1a14102e;margin-top:-9px;cursor:pointer;-webkit-transition:transform .1s;transition:transform .1s}.score-slider::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--accent);border:2px solid var(--bg-elevated);box-shadow:0 1px 3px #1a14102e;cursor:pointer;-moz-transition:transform .1s;transition:transform .1s}.score-slider:active::-webkit-slider-thumb{transform:scale(1.1)}.score-slider:active::-moz-range-thumb{transform:scale(1.1)}.score-value{font-family:var(--serif);font-size:18px;font-weight:500;color:var(--accent);min-width:28px;text-align:right}.score-value.empty{color:var(--ink-faint)}.score-clear{font-size:11px;color:var(--ink-faint);background:transparent;padding:4px 8px;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.06em;font-weight:600;transition:background .15s}.score-clear:active{background:var(--bg-sunken)}.score-clear:disabled{opacity:.3}.cooked-btn{width:100%;padding:12px 16px;margin:0 0 22px;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--bg-elevated);color:var(--ink-soft);font-size:14px;font-weight:500;text-align:center;transition:background .15s;box-shadow:var(--shadow)}.cooked-btn:active{background:var(--bg-sunken)}.card-score{font-size:11px;padding:3px 8px;border-radius:4px;background:var(--accent-bg);color:var(--accent);font-weight:600;letter-spacing:.04em}.card-cooked{font-size:10px;padding:3px 8px;border-radius:4px;background:var(--bg-sunken);color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.utensils-list{display:flex;flex-wrap:wrap;gap:8px;padding:0 4px;margin-bottom:22px}.utensil-tag{display:inline-block;padding:6px 12px;border-radius:8px;font-size:13px;background:var(--bg-sunken);color:var(--ink-soft);border:1px solid var(--line-soft)}.beverage-section{margin-top:8px;margin-bottom:22px}.beverage-card{padding:18px 20px;border-radius:var(--radius);background:var(--accent-bg)}.beverage-card+.beverage-card{margin-top:12px}.beverage-type{font-family:var(--serif);font-size:18px;font-weight:500;color:var(--accent);margin-bottom:10px}.beverage-detail{font-size:14px;color:var(--ink-soft);margin-bottom:4px;display:flex;gap:6px}.beverage-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:600;color:var(--ink-faint);align-self:center}.beverage-reason{margin-top:10px;font-size:14px;line-height:1.5;font-style:italic;color:var(--ink-soft)}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a141066;z-index:150;animation:fadeIn .2s}.drawer{position:fixed;top:0;left:0;bottom:0;width:75%;max-width:300px;background:var(--bg-raised);z-index:200;padding:var(--safe-top) 0 calc(72px + var(--safe-bottom)) 0;box-shadow:var(--shadow-lg);transform:translate(-100%);transition:transform .25s ease-out;overflow-y:auto;display:flex;flex-direction:column}.drawer.open{transform:translate(0)}.drawer-header{padding:20px 20px 18px;border-bottom:1px solid var(--line-soft);margin-bottom:8px;display:flex;align-items:center;gap:12px}.drawer-brand-mark{width:36px;height:36px;border-radius:10px;background:var(--accent);color:#fff;font-family:var(--serif);font-style:italic;font-size:20px;font-weight:500;display:flex;align-items:center;justify-content:center;flex-shrink:0}.drawer-brand-name{font-family:var(--serif);font-weight:400;font-size:20px;letter-spacing:-.01em;color:var(--ink)}.drawer-brand-sub{font-size:12px;color:var(--ink-faint);font-style:italic;font-family:var(--serif);margin-top:1px}.drawer-divider{height:1px;background:var(--line-soft);margin:8px 20px}.drawer-item{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:12px 20px;cursor:pointer;border:0;background:transparent;color:var(--ink-soft);font-family:var(--sans);transition:background .15s,color .15s}.drawer-item:hover{background:var(--bg-sunken)}.drawer-item.active{color:var(--ink);background:var(--accent-tint)}.drawer-item-icon{width:20px;height:20px;stroke-width:1.6;flex-shrink:0;color:inherit}.drawer-item.active .drawer-item-icon{color:var(--accent)}.drawer-item-text{display:flex;flex-direction:column;gap:1px}.drawer-item-label{font-size:15px;font-weight:500}.drawer-item-sub{font-size:12px;color:var(--ink-faint);font-weight:400}.drawer-section-label{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);padding:16px 20px 6px}.dashboard-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px}.dashboard-stat{background:var(--bg-elevated);border-radius:var(--radius);padding:16px 12px;text-align:center;box-shadow:var(--shadow)}.dashboard-stat-value{font-family:var(--serif);font-size:24px;font-weight:500;color:var(--ink);line-height:1;margin-bottom:6px}.dashboard-stat-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint);font-weight:600}.dashboard-recent{margin-top:24px}.dashboard-recent .section-label{margin-bottom:14px}.dashboard-recent-carousel{display:flex;gap:14px;overflow-x:auto;padding-bottom:6px;margin:0 -16px;padding-left:16px;padding-right:16px;scroll-padding:16px;-webkit-overflow-scrolling:touch}.dashboard-recent-carousel::-webkit-scrollbar{display:none}.decouverte-season-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:var(--accent-bg);color:var(--accent);border-radius:var(--radius-lg);font-size:.85rem;font-weight:500;margin-bottom:10px}.decouverte-month{font-family:var(--serif);font-size:1.1rem;color:var(--ink-soft);margin-bottom:18px;font-style:italic}.decouverte-subsection-label{font-size:11px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin:14px 0 10px}.produce-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:6px}.produce-tag{display:inline-flex;align-items:center;gap:6px;padding:6px 6px 6px 12px;background:var(--bg-sunken);border:1px solid var(--line-soft);border-radius:8px;font-size:.85rem;color:var(--ink-soft)}.produce-tag--fruit{border-color:var(--accent-tint)}.produce-tag-cta{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--bg-raised);color:var(--accent);border:none;cursor:pointer;font-size:13px;font-weight:600;line-height:1;padding:0;transition:background .12s}.produce-tag-cta:hover,.produce-tag-cta:active{background:var(--accent-tint)}.decouverte-empty{font-size:14px;color:var(--ink-faint);font-style:italic}.create-mode-toggle{display:flex;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;margin-bottom:18px;background:var(--bg-elevated)}.create-mode-btn{flex:1;padding:10px 8px;font-size:.9rem;text-align:center;color:var(--ink-soft);background:var(--bg-elevated);border-right:1px solid var(--line);font-weight:400;transition:all .15s}.create-mode-btn:last-child{border-right:none}.create-mode-btn.active{background:var(--accent);color:var(--bg);font-weight:500}.fridge-input-row{display:flex;gap:8px;margin-bottom:12px}.fridge-input-row input{flex:1;min-width:0;padding:10px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-elevated);font-size:.95rem;color:var(--ink)}.fridge-input-row input:focus{border-color:var(--accent)}.fridge-input-row button{padding:10px 16px;background:var(--accent);color:var(--bg);border-radius:var(--radius-sm);font-weight:500;font-size:.9rem;white-space:nowrap;transition:opacity .15s}.fridge-input-row button:disabled{opacity:.4}.fridge-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.fridge-tag{display:inline-flex;align-items:center;gap:6px;padding:6px 6px 6px 10px;background:var(--bg-sunken);border:1px solid var(--line-soft);border-radius:8px;font-size:.85rem;color:var(--ink-soft)}.fridge-tag button{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:14px;color:var(--ink-faint);padding:0;line-height:1;transition:background .15s}.fridge-tag button:active{background:var(--line)}.fridge-empty{font-size:.9rem;color:var(--ink-faint);font-style:italic;margin-bottom:8px}.season-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--line);border-radius:var(--radius-lg);font-size:.9rem;color:var(--ink-soft);background:var(--bg-elevated);transition:all .15s}.season-chip:active{transform:scale(.98)}.season-chip.active{background:var(--accent-bg);border-color:var(--accent);color:var(--accent);font-weight:500}.section-helper{font-size:.8rem;color:var(--ink-faint);margin-top:8px}.pairing-search{display:flex;gap:8px;margin-bottom:16px}.pairing-search input{flex:1;min-width:0;padding:10px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-elevated);font-size:.95rem;color:var(--ink)}.pairing-search input:focus{border-color:var(--accent)}.pairing-search button{padding:10px 18px;background:var(--accent);color:var(--bg);border-radius:var(--radius-sm);font-weight:500;font-size:.9rem;white-space:nowrap;transition:opacity .15s}.pairing-search button:disabled{opacity:.4}.pairing-results{margin-top:8px}.pairing-ingredient-name{font-family:var(--serif);font-size:1.4rem;color:var(--ink);margin-bottom:12px}.pairing-ingredient-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.pairing-ingredient-row .pairing-ingredient-name{margin-bottom:0}.decouverte-cta{padding:8px 14px;background:var(--ink);color:var(--bg);border:none;border-radius:999px;font-family:var(--sans);font-size:13px;font-weight:500;cursor:pointer}.decouverte-cta:active{opacity:.9}.planner-shopping-btn{width:100%;padding:14px;background:var(--ink);color:var(--bg);border-radius:var(--radius);font-family:var(--serif);font-size:15px;font-weight:500;letter-spacing:.01em;border:none;cursor:pointer;margin-top:14px;margin-bottom:14px;box-shadow:var(--shadow);transition:transform .12s}.planner-shopping-btn:active{transform:scale(.99)}.planner-shopping-btn:disabled{opacity:.5;cursor:default}.pairing-tip{background:var(--accent-bg);padding:12px 14px;border-radius:var(--radius-sm);font-size:.9rem;color:var(--ink-soft);margin-bottom:16px;font-style:italic}.pairing-tip-label{display:block;font-family:var(--serif);font-style:italic;font-size:.8rem;color:var(--accent);margin-bottom:4px;font-weight:500}.pairing-category{margin-bottom:14px}.pairing-category-label{font-size:.8rem;font-weight:500;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}.pairing-technique{padding:4px 0;font-size:.9rem;color:var(--ink-soft)}.annotation-display{padding:12px 14px;background:var(--bg-sunken);border-radius:var(--radius-sm);cursor:pointer;min-height:44px;margin-bottom:22px;transition:background .15s}.annotation-display:active{background:var(--line-soft)}.annotation-text{font-size:.9rem;color:var(--ink-soft);white-space:pre-wrap;line-height:1.5}.annotation-placeholder{font-size:.9rem;color:var(--ink-faint);font-style:italic}.annotation-edit{display:flex;flex-direction:column;gap:10px;margin-bottom:22px}.annotation-textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-elevated);font-size:.9rem;line-height:1.5;resize:vertical;min-height:80px;color:var(--ink);font-family:inherit}.annotation-textarea:focus{border-color:var(--accent)}.annotation-actions{display:flex;justify-content:flex-end;gap:8px}.annotation-cancel{padding:8px 14px;font-size:.85rem;color:var(--ink-faint);border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-elevated)}.annotation-save{padding:8px 14px;font-size:.85rem;color:var(--bg);background:var(--accent);border-radius:var(--radius-sm);font-weight:500}.instruction-content{flex:1}.timer{display:flex;align-items:center;gap:10px;padding:8px 12px;margin-top:8px;background:var(--bg-sunken);border-radius:var(--radius-sm);border:1px solid var(--line-soft)}.timer--running{border-color:var(--accent);background:var(--accent-bg)}.timer--complete{border-color:var(--green);background:color-mix(in srgb,var(--green) 10%,transparent);animation:timer-pulse 1s ease-in-out 3}@keyframes timer-pulse{0%,to{opacity:1}50%{opacity:.6}}.timer-label{font-size:.8rem;color:var(--ink-soft);flex:1;line-height:1.3}.timer-display{font-family:var(--sans);font-variant-numeric:tabular-nums;font-size:1.1rem;font-weight:600;color:var(--ink);min-width:50px;text-align:center}.timer-controls{display:flex}.timer-btn{padding:4px 10px;font-size:.8rem;border-radius:6px;font-weight:500}.timer-btn--start,.timer-btn--resume{background:var(--accent);color:var(--bg)}.timer-btn--pause{background:var(--bg-elevated);color:var(--ink-soft);border:1px solid var(--line)}.timer-btn--reset{background:var(--bg-elevated);color:var(--ink-faint);border:1px solid var(--line)}.detail-edit-btn{padding:8px 14px;font-size:.85rem;color:var(--ink-soft);border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-elevated);margin-bottom:14px;width:100%}.detail-edit-btn:active{background:var(--bg-sunken)}.filter-toggle{display:flex;align-items:center;gap:6px;padding:8px 14px;font-size:.9rem;color:var(--ink-soft);border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-elevated);margin-bottom:16px}.filter-active-dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}.filter-section{background:var(--bg-elevated);border:1px solid var(--line-soft);border-radius:var(--radius);padding:16px;margin-bottom:16px}.filter-search{width:100%;padding:10px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg);font-size:.95rem;margin-bottom:14px;color:var(--ink)}.filter-search:focus{border-color:var(--accent)}.filter-row{margin-bottom:12px}.filter-row:last-of-type{margin-bottom:0}.filter-row-label{font-size:.8rem;font-weight:500;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.filter-chips{display:flex;flex-wrap:wrap;gap:6px}.filter-chip{padding:5px 10px;font-size:.8rem;border:1px solid var(--line);border-radius:var(--radius-lg);color:var(--ink-soft);background:var(--bg)}.filter-chip.active{background:var(--accent);border-color:var(--accent);color:var(--bg)}.filter-sort{width:100%;padding:8px 12px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg);font-size:.9rem;color:var(--ink)}.filter-reset-btn{padding:8px 14px;font-size:.85rem;color:var(--accent);border:1px solid var(--accent);border-radius:var(--radius-sm);background:transparent;margin-top:8px}.filter-cooked-toggle{display:flex;align-items:center;gap:8px;font-size:.9rem;color:var(--ink-soft);cursor:pointer}.score-filter-chips{display:flex;flex-wrap:wrap;gap:6px}.score-filter-chip{padding:5px 10px;font-size:.8rem;border:1px solid var(--line);border-radius:var(--radius-lg);color:var(--ink-soft);background:var(--bg);min-width:36px;text-align:center}.score-filter-chip.active{background:var(--accent);border-color:var(--accent);color:var(--bg)}.batch-priority{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-top:1px solid var(--line-soft);font-size:.9rem;color:var(--ink-soft);cursor:pointer}.batch-priority:first-of-type{border-top:none}.batch-priority input{margin-top:3px;flex-shrink:0}.batch-priority strong{display:block;color:var(--ink);font-weight:500;margin-bottom:2px}.batch-priority small{display:block;font-size:.8rem;color:var(--ink-faint);line-height:1.3}.batch-plan{background:var(--bg-elevated);border:1px solid var(--line-soft);border-radius:var(--radius);padding:16px;margin-bottom:20px;box-shadow:var(--shadow)}.batch-plan-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px;gap:10px;flex-wrap:wrap}.batch-plan-title{font-family:var(--serif);font-size:1.1rem;color:var(--ink)}.batch-plan-time{font-size:.85rem;color:var(--accent);font-weight:500}.batch-common-ingredients{margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--line-soft)}.batch-common-label{font-size:.8rem;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:8px}.batch-common-tags{display:flex;flex-wrap:wrap;gap:6px}.batch-common-tag{padding:4px 10px;font-size:.8rem;border-radius:var(--radius-lg);background:var(--bg-sunken);color:var(--ink-soft)}.batch-step{display:flex;gap:12px;padding:10px 0;border-top:1px solid var(--line-soft)}.batch-step:first-of-type{border-top:none}.batch-step-num{width:24px;height:24px;border-radius:50%;background:var(--accent);color:var(--bg);font-size:.75rem;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.batch-step-content{flex:1;min-width:0}.batch-step-text{font-size:.9rem;color:var(--ink);line-height:1.4}.batch-step-meta{display:flex;gap:12px;margin-top:4px;font-size:.8rem;color:var(--ink-faint);flex-wrap:wrap}.batch-step-time{color:var(--accent)}.batch-recipe-label{font-size:.8rem;font-weight:500;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;margin-top:12px}.planner-create{display:flex;flex-direction:column;gap:8px}.planner-date-input{max-width:180px}.planner-create-btn{align-self:flex-start;margin-top:12px}.planner-archive-note{display:flex;flex-direction:column;gap:8px;background:var(--bg-sunken)}.planner-grid-section{padding-left:0;padding-right:0;overflow:hidden}.planner-grid{display:grid;grid-template-columns:80px repeat(var(--planner-days),minmax(100px,1fr));gap:4px;padding:0 12px 8px;overflow-x:auto;-webkit-overflow-scrolling:touch}.planner-row-header{position:sticky;left:0;background:var(--bg);z-index:2;padding:8px 6px;font-size:.7rem;font-weight:500;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center}.planner-corner{background:var(--bg);position:sticky;left:0;z-index:3}.planner-day-header{text-align:center;padding:6px 2px;font-size:.75rem;color:var(--ink-soft);text-transform:capitalize}.planner-day-header-date{font-weight:600;font-size:.95rem;color:var(--ink);font-family:var(--serif)}.planner-slot{min-height:60px;border:1px dashed var(--line-soft);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;padding:6px;background:transparent;color:var(--ink);transition:background .15s;width:100%}.planner-slot:active{background:var(--bg-sunken)}.planner-slot--empty{color:var(--ink-faint);font-size:1.2rem}.planner-slot--filled{border-style:solid;border-color:var(--line);background:var(--bg-elevated);flex-direction:column;gap:2px}.planner-slot-wrap{position:relative}.planner-slot-title{font-size:.7rem;color:var(--ink);text-align:center;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.2}.planner-slot-time{font-size:.65rem;color:var(--ink-faint)}.planner-slot-menu{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:4px;background:var(--bg-elevated);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:10;display:flex;flex-direction:column;min-width:180px;overflow:hidden}.planner-slot-menu button{padding:10px 14px;background:transparent;border:none;text-align:left;font-size:.85rem;color:var(--ink);cursor:pointer}.planner-slot-menu button:hover,.planner-slot-menu button:active{background:var(--bg-sunken)}.planner-slot-menu button.danger{color:var(--accent)}.planner-actions{display:flex;gap:8px;flex-wrap:wrap}.planner-actions button{flex:1;min-width:160px}.planner-fill{display:flex;flex-direction:column;gap:10px}.planner-fill-btn{align-self:stretch}.planner-filling{display:flex;align-items:center;gap:10px;color:var(--ink-soft);font-size:.85rem}.planner-filling .loading-spinner{width:18px;height:18px;margin:0}.slot-picker-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a141073;z-index:50;display:flex;align-items:flex-end;justify-content:center;padding:16px;padding-top:calc(var(--safe-top) + 16px)}.slot-picker{background:var(--bg);border-radius:var(--radius-lg);width:100%;max-width:520px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-lg)}.slot-picker-header{padding:16px;border-bottom:1px solid var(--line-soft)}.slot-picker-title-row{display:flex;align-items:center;justify-content:space-between}.slot-picker-title-row h3{font-family:var(--serif);font-size:1.3rem;font-weight:500;margin:0}.slot-picker-close{background:transparent;border:none;font-size:1.8rem;line-height:1;color:var(--ink-faint);cursor:pointer;padding:0 4px}.slot-picker-context{font-size:.8rem;color:var(--ink-faint);margin-top:2px;text-transform:capitalize}.slot-picker-search{margin-top:10px;width:100%;padding:10px 12px;background:var(--bg-sunken);border:1px solid transparent;border-radius:var(--radius-sm);font-size:.9rem;color:var(--ink)}.slot-picker-search:focus{outline:none;border-color:var(--line)}.slot-picker-body{flex:1;overflow-y:auto;padding:8px}.slot-picker-section-label{font-size:.7rem;font-weight:600;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em;padding:10px 8px 6px}.slot-picker-row{display:block;width:100%;text-align:left;background:transparent;border:none;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;color:var(--ink)}.slot-picker-row:hover,.slot-picker-row:active{background:var(--bg-sunken)}.slot-picker-row-title{font-size:.95rem;font-weight:500;color:var(--ink);margin-bottom:2px}.slot-picker-row-meta{font-size:.75rem;color:var(--ink-faint)}.slot-picker-empty{padding:24px 12px;text-align:center;color:var(--ink-faint);font-size:.9rem}.slot-picker-footer{padding:12px 16px;border-top:1px solid var(--line-soft);display:flex;justify-content:flex-end}.dashboard-nutrition{margin-top:20px;margin-bottom:24px}.dashboard-nutrition-header{display:flex;justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:6px;flex-wrap:wrap}.dashboard-nutrition-meals{font-size:.8rem;color:var(--ink-faint)}.dashboard-nutrition-sublabel{font-size:.75rem;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}.dashboard-nutrition-empty{font-size:.9rem;color:var(--ink-faint);background:var(--bg-elevated);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);line-height:1.4}.dashboard-nutrition .nutrition{margin-bottom:14px}.macro-bar-container{margin-top:4px}.macro-bar{display:flex;height:12px;border-radius:6px;overflow:hidden;background:var(--bg-sunken)}.macro-bar-segment{transition:width .3s ease}.macro-bar--protein{background:var(--accent)}.macro-bar--carbs{background:var(--ink-faint)}.macro-bar--fat{background:#d4956a}.macro-legend{display:flex;gap:14px;margin-top:8px;flex-wrap:wrap}.macro-legend-item{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--ink-soft)}.macro-dot{width:8px;height:8px;border-radius:50%}.macro-dot--protein{background:var(--accent)}.macro-dot--carbs{background:var(--ink-faint)}.macro-dot--fat{background:#d4956a}.fav-tabs{display:flex;gap:6px;margin:6px 0 14px;background:var(--bg-sunken);border-radius:var(--radius-sm);padding:4px}.fav-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 10px;border-radius:8px;font-size:13px;font-weight:500;color:var(--ink-soft);transition:background .15s,color .15s}.fav-tab.active{background:var(--bg-elevated);color:var(--ink);box-shadow:0 1px 2px #1a14100f}.fav-tab-count{font-size:11px;color:var(--ink-faint);font-variant-numeric:tabular-nums}.fav-tab.active .fav-tab-count{color:var(--accent)}.collection-fav-list{display:flex;flex-direction:column;gap:10px}.collection-fav-card{background:var(--bg-elevated);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.collection-fav-header{width:100%;text-align:left;padding:14px 18px;display:flex;flex-direction:column;gap:4px}.collection-fav-header:active{background:var(--bg-sunken)}.collection-fav-title{font-family:var(--serif);font-size:17px;font-weight:500;color:var(--ink)}.collection-fav-meta{font-size:12px;color:var(--ink-faint)}.collection-fav-body{padding:8px 18px 18px;border-top:1px solid var(--line-soft)}.detail-view{margin:0 -20px}.detail-view>.section-label,.detail-view>.detail-meta-pills,.detail-view>.detail-tabs,.detail-view>.detail-tab-content{padding-left:20px;padding-right:20px}.detail-hero{position:relative;height:300px;overflow:hidden;background:var(--bg-sunken);padding:0;margin:0}.detail-hero-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.detail-hero-gradient{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(0,0,0,.25) 0%,transparent 35%,transparent 55%,rgba(0,0,0,.7) 100%);pointer-events:none}.detail-hero-top{position:absolute;top:14px;left:14px;right:14px;display:flex;justify-content:space-between;align-items:center;padding-top:var(--safe-top,0)}.detail-hero-bottom{position:absolute;left:20px;right:20px;bottom:18px}.detail-hero-eyebrow{font-family:var(--serif);font-style:italic;font-size:13px;color:#ffffffd9;margin-bottom:6px;text-shadow:0 1px 3px rgba(0,0,0,.45)}.detail-hero-title{font-family:var(--serif);font-size:30px;line-height:34px;font-weight:500;letter-spacing:-.015em;color:#fff;text-shadow:0 2px 6px rgba(0,0,0,.5);margin:0;font-variation-settings:"opsz" 144}.detail-glassy-btn{width:38px;height:38px;border-radius:50%;background:#ffffffd9;backdrop-filter:blur(8px) saturate(150%);-webkit-backdrop-filter:blur(8px) saturate(150%);box-shadow:0 1px 3px #0000002e;border:none;cursor:pointer;color:var(--ink);display:flex;align-items:center;justify-content:center}.detail-glassy-btn svg{width:18px;height:18px;stroke-width:1.8}.detail-glassy-btn.active{color:var(--accent)}.detail-glassy-btn.active svg{fill:var(--accent);stroke:var(--accent)}.detail-hero-actions{position:absolute;right:16px;bottom:16px;display:flex;align-items:center;gap:10px}.detail-photo-dots{display:flex;align-items:center;gap:6px}.detail-photo-dot{width:6px;height:6px;border-radius:3px;background:#ffffff80;border:none;padding:0;cursor:pointer;transition:width .15s,background .15s}.detail-photo-dot.active{width:18px;background:#fffffff2}.detail-camera-btn{width:34px;height:34px;border-radius:50%;background:#ffffffd9;backdrop-filter:blur(8px) saturate(150%);-webkit-backdrop-filter:blur(8px) saturate(150%);box-shadow:0 1px 3px #0000002e;border:none;cursor:pointer;color:var(--ink);display:flex;align-items:center;justify-content:center}.detail-camera-btn:disabled{opacity:.6;cursor:default}.detail-camera-btn svg{width:16px;height:16px;stroke-width:1.7}.detail-camera-spin{width:14px;height:14px;border:2px solid var(--ink-faint);border-top-color:var(--ink);border-radius:50%;animation:spin .8s linear infinite}.detail-photo-input{display:none}.detail-meta-pills{display:flex;flex-wrap:wrap;gap:6px;padding:16px 20px 4px;margin:0}.detail-meta-pill{font-family:var(--sans);font-size:12px;line-height:15px;font-weight:500;background:var(--bg-sunken);color:var(--ink-soft);padding:5px 11px;border-radius:999px}.detail-tabs{display:grid;grid-template-columns:repeat(3,1fr);background:var(--bg-sunken);border-radius:var(--radius-sm);padding:4px;margin:14px 20px 18px;gap:0}.detail-tab{padding:9px;background:transparent;border:none;border-radius:calc(var(--radius-sm) - 2px);font-family:var(--sans);font-size:13px;font-weight:500;color:var(--ink-soft);cursor:pointer;transition:background .15s,color .15s}.detail-tab.active{background:var(--bg-raised);color:var(--ink);box-shadow:0 1px 3px #0000000f}.detail-tab-content{padding:0 20px 30px}.detail-servings-row{display:flex;justify-content:space-between;align-items:center;gap:12px;background:var(--bg-raised);border-radius:var(--radius);padding:14px 18px;margin-bottom:22px;box-shadow:var(--shadow);flex-wrap:wrap}.detail-stepper{display:flex;align-items:center;gap:10px}.detail-stepper-label{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--ink-soft)}.detail-unit-toggle{display:flex;background:var(--bg-sunken);border-radius:999px;padding:3px}.detail-unit-toggle button{padding:8px 14px;background:transparent;border:none;border-radius:999px;font-family:var(--sans);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);cursor:pointer;transition:background .15s,color .15s}.detail-unit-toggle button.active{background:var(--bg-raised);color:var(--ink);box-shadow:0 1px 3px #0000000f}.detail-ingredients{background:var(--bg-raised);border:1px solid var(--line-soft);border-radius:var(--radius);padding:6px 18px;margin-bottom:22px;box-shadow:var(--shadow)}.detail-ingredient-row{display:flex;align-items:baseline;gap:14px;padding:13px 0;border-bottom:1px solid var(--line-soft)}.detail-ingredient-row:last-child{border-bottom:none}.detail-ingredient-qty{font-family:var(--serif);font-size:15px;font-weight:500;color:var(--accent);font-variant-numeric:tabular-nums;min-width:64px;flex-shrink:0}.detail-ingredient-name{font-family:var(--sans);font-size:15px;color:var(--ink);flex:1}.detail-steps{background:var(--bg-raised);border:1px solid var(--line-soft);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);margin-bottom:22px}.detail-step{display:flex;gap:14px;padding:12px 0;border-bottom:1px solid var(--line-soft)}.detail-step:last-child{border-bottom:none}.detail-step-num{width:28px;height:28px;border-radius:50%;background:var(--accent-tint);color:var(--accent);font-family:var(--serif);font-size:15px;font-weight:500;display:flex;align-items:center;justify-content:center;flex-shrink:0}.detail-step-content{flex:1;min-width:0}.detail-step-text{font-family:var(--sans);font-size:15px;line-height:22px;color:var(--ink-soft)}.detail-cook-btn{width:100%;padding:18px;background:var(--ink);color:var(--bg);border-radius:var(--radius);font-family:var(--serif);font-size:17px;font-weight:500;letter-spacing:.01em;border:none;cursor:pointer;box-shadow:var(--shadow);transition:transform .12s}.detail-cook-btn:active{transform:scale(.99)}.detail-kcal-hero{background:var(--bg-raised);border:1px solid var(--line-soft);border-radius:var(--radius);padding:24px 20px;margin-bottom:18px;text-align:center;box-shadow:var(--shadow)}.detail-kcal-overline{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:6px}.detail-kcal-value{font-family:var(--serif);font-size:54px;line-height:1;font-weight:500;color:var(--accent);letter-spacing:-.02em}.detail-kcal-unit{font-family:var(--sans);font-size:13px;color:var(--ink-faint);margin-top:6px}.detail-macro-bar{display:flex;height:14px;border-radius:7px;overflow:hidden;background:var(--bg-sunken);margin-bottom:14px}.detail-macro-bar-protein{background:var(--accent)}.detail-macro-bar-carbs{background:var(--accent-2)}.detail-macro-bar-fat{background:var(--warn)}.detail-macro-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px}.detail-macro-cell{display:flex;align-items:flex-start;gap:8px;background:var(--bg-raised);border:1px solid var(--line-soft);border-radius:var(--radius-sm);padding:12px}.detail-macro-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:5px}.detail-macro-dot-protein{background:var(--accent)}.detail-macro-dot-carbs{background:var(--accent-2)}.detail-macro-dot-fat{background:var(--warn)}.detail-macro-label{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:3px}.detail-macro-value{font-family:var(--serif);font-size:18px;font-weight:500;color:var(--ink);line-height:1}.detail-macro-unit{font-family:var(--sans);font-size:11px;color:var(--ink-faint);margin-left:2px;font-weight:400}.detail-macro-pct{font-family:var(--sans);font-size:12px;color:var(--ink-faint);margin-top:2px}.detail-stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:22px}.detail-stat-card{background:var(--bg-raised);border:1px solid var(--line-soft);border-radius:var(--radius-sm);padding:14px}.detail-stat-overline{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:6px}.detail-stat-value{font-family:var(--serif);font-size:22px;font-weight:500;color:var(--ink);line-height:1}.detail-stat-unit{font-family:var(--sans);font-size:12px;color:var(--ink-faint);margin-left:2px;font-weight:400}.detail-score-row{display:flex;align-items:center;gap:12px;margin-bottom:18px}.detail-score-overline{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);flex-shrink:0}.detail-score-bars{display:flex;gap:3px;flex:1}.detail-score-bar{flex:1;height:18px;background:var(--bg-sunken);border:none;border-radius:3px;cursor:pointer;padding:0;transition:background .12s}.detail-score-bar.filled{background:var(--accent)}.detail-score-value{font-family:var(--serif);font-size:18px;font-weight:500;color:var(--accent);min-width:24px;text-align:right}.detail-cooked-card{display:flex;align-items:center;justify-content:space-between;gap:14px;background:var(--bg-raised);border:1px solid var(--line-soft);border-radius:var(--radius);padding:14px 18px;margin-bottom:18px;box-shadow:var(--shadow)}.detail-cooked-overline{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:4px}.detail-cooked-count{font-family:var(--serif);font-size:22px;font-weight:500;color:var(--ink);line-height:1}.detail-cooked-when{font-family:var(--sans);font-size:12px;color:var(--ink-faint);margin-top:4px}.detail-cooked-btn{padding:9px 14px;background:var(--accent);color:var(--bg);border:none;border-radius:999px;font-family:var(--sans);font-size:13px;font-weight:500;cursor:pointer;flex-shrink:0}.detail-cooked-btn:active{opacity:.9}.detail-beverage-card{display:flex;gap:12px;background:var(--accent-tint);border-radius:var(--radius);padding:16px 18px;margin-bottom:10px}.detail-beverage-icon{width:34px;height:34px;border-radius:50%;background:var(--bg-raised);color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}.detail-beverage-icon svg{width:18px;height:18px;stroke-width:1.6}.detail-beverage-body{flex:1;min-width:0}.detail-beverage-type{font-family:var(--serif);font-size:16px;font-weight:500;color:var(--accent-ink);margin-bottom:2px}.detail-beverage-meta{font-family:var(--sans);font-size:12px;color:var(--accent-ink);opacity:.8;margin-bottom:6px}.detail-beverage-reason{font-family:var(--sans);font-size:13px;line-height:18px;color:var(--ink-soft);font-style:italic}.detail-utensil-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}.detail-utensil-chip{display:inline-block;padding:6px 12px;border-radius:999px;font-family:var(--sans);font-size:12px;background:var(--bg-sunken);color:var(--ink-soft)}.detail-action-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:6px}.detail-action-btn{padding:12px;background:var(--bg-raised);border:1px solid var(--line);border-radius:var(--radius-sm);font-family:var(--sans);font-size:14px;font-weight:500;color:var(--ink);cursor:pointer;transition:background .12s}.detail-action-btn:active{background:var(--bg-sunken)}.detail-action-btn-primary{background:var(--ink);color:var(--bg);border-color:var(--ink)}.detail-notes-empty{background:var(--bg-raised);border:1px solid var(--line-soft);border-radius:var(--radius);padding:24px 22px;text-align:center;box-shadow:var(--shadow)}.detail-notes-empty-title{font-family:var(--serif);font-size:18px;font-weight:500;color:var(--ink);margin-bottom:6px}.detail-notes-empty-text{font-family:var(--sans);font-size:13px;line-height:18px;color:var(--ink-soft);margin:0 0 16px}.cook-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:400;background:var(--cook-bg);color:var(--cook-fg);font-family:var(--sans);overflow-y:auto;padding:calc(var(--safe-top) + 16px) 20px calc(var(--safe-bottom) + 24px);display:flex;flex-direction:column;gap:18px}.cook-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px}.cook-topbar-titles{flex:1;min-width:0}.cook-topbar-overline{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--cook-accent);margin-bottom:4px}.cook-topbar-title{font-family:var(--serif);font-size:20px;font-weight:500;color:var(--cook-fg);letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cook-close-btn{width:36px;height:36px;border-radius:50%;background:var(--cook-surface);color:var(--cook-fg);display:flex;align-items:center;justify-content:center;flex-shrink:0;border:none;cursor:pointer}.cook-close-btn svg{width:18px;height:18px;stroke-width:2}.cook-ingredients{background:var(--cook-surface);border-radius:var(--radius);padding:14px 16px}.cook-ingredients-header{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--cook-fg-soft);margin-bottom:10px}.cook-ingredient{display:flex;align-items:center;gap:12px;width:100%;min-height:44px;padding:8px 0;background:transparent;border:none;text-align:left;cursor:pointer;color:var(--cook-fg)}.cook-ingredient-checkbox{width:22px;height:22px;border-radius:6px;background:transparent;border:1.5px solid var(--cook-surface-b);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:background .12s,border-color .12s}.cook-ingredient-checkbox.checked{background:var(--cook-accent);border-color:var(--cook-accent)}.cook-ingredient-checkbox svg{width:14px;height:14px;stroke-width:2.4;color:var(--cook-bg)}.cook-ingredient-text{font-family:var(--sans);font-size:15px;line-height:21px;color:var(--cook-fg);flex:1}.cook-ingredient-text.checked{text-decoration:line-through;color:var(--cook-fg-faint)}.cook-ingredient-qty{font-family:var(--serif);color:var(--cook-accent);font-weight:500}.cook-step-block{padding:6px 0}.cook-step-num{font-family:var(--serif);font-size:44px;line-height:1;color:var(--cook-accent);font-weight:500;margin-bottom:14px}.cook-step-num-total{font-family:var(--sans);font-size:13px;color:var(--cook-fg-faint);font-weight:400;letter-spacing:.04em}.cook-step-text{font-family:var(--sans);font-size:19px;line-height:27px;color:var(--cook-fg)}.cook-timer{background:linear-gradient(180deg,var(--cook-surface) 0%,var(--cook-surface-b) 100%);border-radius:var(--radius);padding:18px 20px;text-align:center}.cook-timer-overline{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--cook-accent);margin-bottom:10px}.cook-timer-display{font-family:var(--serif);font-size:64px;line-height:1;font-weight:500;color:var(--cook-fg);font-variant-numeric:tabular-nums;margin-bottom:14px;letter-spacing:-.01em}.cook-timer-controls{display:flex;gap:10px;justify-content:center}.cook-timer-btn{padding:10px 18px;background:var(--cook-accent);color:var(--cook-bg);border:none;border-radius:999px;font-family:var(--sans);font-size:14px;font-weight:500;cursor:pointer}.cook-timer-btn:disabled{opacity:.5;cursor:default}.cook-timer-reset{padding:10px 18px;background:var(--cook-surface-b);color:var(--cook-fg);border:none;border-radius:999px;font-family:var(--sans);font-size:14px;font-weight:500;cursor:pointer}.cook-nav{display:flex;gap:10px;margin-top:auto}.cook-nav-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:14px;border:none;border-radius:var(--radius);font-family:var(--sans);font-size:15px;font-weight:500;cursor:pointer;transition:opacity .12s}.cook-nav-btn svg{width:16px;height:16px;stroke-width:2}.cook-nav-prev{background:var(--cook-surface);color:var(--cook-fg)}.cook-nav-prev:disabled{opacity:.4;cursor:default}.cook-nav-next{background:var(--cook-accent);color:var(--cook-bg)}.cook-progress-dots{display:flex;justify-content:center;align-items:center;gap:6px;padding-top:4px}.cook-progress-dot{width:6px;height:6px;border-radius:3px;background:var(--cook-surface-b);transition:width .15s,background .15s}.cook-progress-dot.done{background:var(--cook-fg-faint)}.cook-progress-dot.active{width:18px;background:var(--cook-accent)}@media (min-width:600px){.header h1{font-size:42px}.nutrition-value{font-size:22px}}*,:before,:after{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / .5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / .5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:var(--sans);font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.\!visible{visibility:visible!important}.visible{visibility:visible}.absolute{position:absolute}.table{display:table}.contents{display:contents}.capitalize{text-transform:capitalize}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}
