:root{--bg:#0e0e10;--card:#1a1a1f;--border:#2a2a30;--text:#f0f0f2;--text2:#8e8e96;--text3:#555;--accent:#c9a96e;--accent-bg:#c9a96e1f;--green:#4caf50;--green-bg:#4caf501f;--red:#e25252;--red-bg:#e552521f;--blue:#2a5daa;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;font:15px/145% DM Sans,system-ui,sans-serif}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);overscroll-behavior-y:none;margin:0}#app{flex-direction:column;min-height:100svh;display:flex}h1,h2,h3{margin:0;font-weight:500}p{margin:0}button{cursor:pointer;font-family:inherit}button:active{transform:scale(.97)}input,select,textarea{background:var(--card);border:1px solid var(--border);color:var(--text);border-radius:10px;padding:10px 12px;font-family:inherit;font-size:15px}input:focus,select:focus,textarea:focus{border-color:var(--accent);outline:none}.search-bar{align-items:center;display:flex;position:relative}.search-bar input{width:100%;padding-left:36px;padding-right:32px}.search-bar input[type=search]::-webkit-search-cancel-button{appearance:none}.search-icon{color:var(--text3);pointer-events:none;position:absolute;left:12px}.search-clear{color:var(--text3);background:0 0;border:none;padding:8px;font-size:13px;line-height:1;position:absolute;right:6px}.label{text-transform:uppercase;letter-spacing:.5px;color:var(--text2);font-size:12px}.badge{border-radius:100px;padding:3px 9px;font-size:12px;display:inline-block}.badge-ok{color:var(--green);background:var(--green-bg)}.badge-low{color:var(--accent);background:var(--accent-bg)}.badge-out{color:var(--red);background:var(--red-bg)}.screen-area{flex-direction:column;flex:1;display:flex;overflow-y:auto}.screen{flex:1;padding-bottom:24px}.bottom-nav{border-top:1px solid var(--border);background:var(--card);padding-bottom:env(safe-area-inset-bottom);z-index:5;display:flex;position:sticky;bottom:0}.nav-item{color:var(--text2);flex-direction:column;flex:1;align-items:center;gap:2px;padding:10px 0 8px;font-size:11px;text-decoration:none;display:flex}.nav-item.active{color:var(--accent)}.nav-icon{font-size:18px}.hero-wrap{margin-bottom:20px;padding:0 20px}.hero-card{text-align:left;background:var(--card);border:1px solid var(--border);width:100%;color:var(--text);border-radius:18px;padding:20px;display:block}.hero-card.hero-resume{background:var(--accent-bg);border-color:var(--accent)}.hero-card.hero-empty{background:0 0;border-style:dashed}.hero-badge{text-transform:uppercase;letter-spacing:.5px;color:var(--accent);align-items:center;gap:6px;margin-bottom:10px;font-size:12px;display:flex}.hero-title{margin-bottom:6px;font-size:20px;font-weight:500}.hero-sub{color:var(--text2);font-size:13px}.hero-cta{color:var(--accent);align-items:center;gap:4px;margin-top:16px;font-size:14px;font-weight:500;display:flex}.home-stats{gap:10px;margin-bottom:24px;padding:0 20px;display:flex}.stat-chip{text-align:left;background:var(--card);border:1px solid var(--border);min-width:0;color:var(--text);border-radius:14px;flex-direction:column;flex:1;align-items:flex-start;gap:8px;padding:14px 12px;display:flex}.stat-chip-icon{background:var(--accent-bg);width:36px;height:36px;color:var(--accent);border-radius:10px;justify-content:center;align-items:center;display:flex}.stat-chip-main{font-size:20px;font-weight:500}.stat-chip-label{color:var(--text2);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12px;display:-webkit-box;overflow:hidden}.pantry-ring{flex-shrink:0}.home-section{margin-bottom:8px}.home-section-label{padding:0 20px 8px}.carousel{scroll-snap-type:x mandatory;gap:12px;padding:0 20px 4px;display:flex;overflow-x:auto}.carousel-card{scroll-snap-align:start;text-align:left;background:var(--card);border:1px solid var(--border);width:140px;color:var(--text);border-radius:14px;flex-direction:column;flex-shrink:0;gap:6px;padding:14px;display:flex}.carousel-card-icon{background:var(--accent-bg);width:32px;height:32px;color:var(--accent);border-radius:8px;justify-content:center;align-items:center;display:flex}.carousel-card-name{text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:500;overflow:hidden}.carousel-card-meta{color:var(--text2);font-size:12px}.screen-header{flex-direction:column;gap:12px;padding:20px 20px 12px;display:flex}.screen-header h2{font-size:18px}.btn-primary{background:var(--accent);color:var(--bg);border:none;border-radius:12px;width:100%;padding:14px;font-size:15px;font-weight:500}.btn-secondary{background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:12px;flex:1;padding:12px;font-size:14px}.btn-danger{background:var(--red-bg);color:var(--red);border:none;border-radius:12px;width:100%;margin-top:8px;padding:14px}.pantry-add-row{gap:10px;padding:0 20px 16px;display:flex}.pantry-group-title{padding:16px 20px 8px}.pantry-row{align-items:center;gap:12px;padding:12px 20px;display:flex}.pantry-icon-wrap{flex-shrink:0;width:38px;height:38px;position:relative}.pantry-icon-fallback{background:var(--accent-bg);color:var(--accent);border-radius:10px;justify-content:center;align-items:center;font-size:14px;font-weight:500;display:flex;position:absolute;inset:0}.pantry-icon-img{object-fit:cover;border-radius:10px;width:100%;height:100%;position:absolute;inset:0}.pantry-item-ring{flex-shrink:0}.pantry-row-main{flex:1;min-width:0}.pantry-row-name{font-size:15px}.pantry-row-sub{color:var(--text2);font-size:13px}.action-details{background:var(--accent);color:#0e0e10}.action-edit{background:var(--blue)}.action-delete{background:var(--red)}.form{flex-direction:column;gap:6px;display:flex}.form label{margin-top:8px}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-row>div{min-width:0}.form-row input,.form-row select{width:100%}.form .btn-primary{margin-top:16px}.swipe-wrap{border-bottom:1px solid var(--border);position:relative;overflow:hidden}.swipe-content{background:var(--bg);z-index:1;position:relative}.swipe-actions{display:flex;position:absolute;top:0;bottom:0}.swipe-actions-right{right:0}.swipe-actions-left{left:0}.swipe-actions button{color:var(--text);border:none;flex:1;font-size:14px}.modal-overlay{z-index:100;background:#0009;align-items:flex-end;display:flex;position:fixed;inset:0}.modal{overscroll-behavior-y:contain;background:var(--card);width:100%;max-height:85vh;padding:24px 20px calc(24px + env(safe-area-inset-bottom));border-radius:20px 20px 0 0;position:relative;overflow:hidden auto}.modal-grabber{background:var(--border);border-radius:2px;width:36px;height:4px;position:absolute;top:8px;left:50%;transform:translate(-50%)}.modal-close{color:var(--text2);background:0 0;border:none;font-size:18px;line-height:1;position:absolute;top:16px;right:16px}.modal-title{margin-bottom:16px;padding-right:24px;font-size:18px}.error-fallback{text-align:center;color:var(--text2);padding:32px 20px}.error-fallback p:nth-child(2){color:var(--red);word-break:break-word;margin:8px 0 16px;font-size:13px}.error-fallback button{background:var(--accent-bg);color:var(--accent);border:none;border-radius:10px;padding:10px 20px}.empty-state{text-align:center;color:var(--text3);white-space:pre-line;padding:48px 20px}.shop-item{align-items:center;gap:14px;padding:14px 20px;display:flex}.shop-check{border:2px solid var(--border);color:#0000;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;transition:background .15s,border-color .15s,color .15s;display:flex}.shop-check.done{background:var(--accent);border-color:var(--accent);color:#000}.shop-info{flex:1;min-width:0}.shop-name{font-size:15px;transition:color .15s}.shop-name.struck{color:var(--text3);text-decoration:line-through}.shop-qty{color:var(--text2);margin-top:2px;font-size:13px}.shop-recipe-badge{background:var(--accent-bg);color:var(--accent);border-radius:6px;margin-top:4px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.shop-checked-header{justify-content:space-between;align-items:center;padding:16px 20px 4px;display:flex}.btn-text{color:var(--accent);background:0 0;border:none;padding:4px;font-size:13px}.btn-text:disabled{color:var(--text3)}.history-insights{gap:12px;padding:12px 20px;display:flex;overflow-x:auto}.history-insight-chip{background:var(--card);border:1px solid var(--border);white-space:nowrap;color:var(--text2);border-radius:10px;padding:8px 14px;font-size:13px}.history-insight-chip strong{color:var(--text)}.history-row{border-bottom:1px solid var(--border);cursor:pointer;flex-direction:column;gap:4px;padding:14px 20px;display:flex}.history-row:active{background:var(--card)}.history-row-name{font-size:15px}.history-row-meta{color:var(--text2);flex-wrap:wrap;gap:10px;font-size:13px;display:flex}.history-row-notes{color:var(--text3);font-size:13px;font-style:italic}.stars{gap:2px;display:flex}.star{cursor:pointer;color:var(--text3);font-size:16px}.star.filled{color:var(--accent)}.recipe-card-tags{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.recipe-card-tag{background:var(--green-bg);color:var(--green);border-radius:6px;padding:2px 8px;font-size:12px}.cook-featured{background:var(--accent-bg);border:1px solid var(--accent);text-align:left;width:calc(100% - 40px);color:inherit;border-radius:14px;align-items:center;gap:12px;margin:0 20px 16px;padding:14px 16px;display:flex}.cook-featured-label{text-transform:uppercase;letter-spacing:.5px;color:var(--accent);align-items:center;gap:5px;margin-bottom:3px;font-size:11px;font-weight:500;display:flex}.cook-featured-name{white-space:nowrap;text-overflow:ellipsis;font-size:16px;font-weight:500;overflow:hidden}.cook-featured-arrow{color:var(--accent);flex-shrink:0;margin-left:auto}.quick-picks{scroll-snap-type:x proximity;scrollbar-width:none;gap:10px;padding:0 20px 18px;display:flex;overflow-x:auto}.quick-picks::-webkit-scrollbar{display:none}.quick-pick-card{scroll-snap-align:start;background:var(--card);border:1px solid var(--border);text-align:left;min-width:104px;color:inherit;border-radius:12px;flex-shrink:0;padding:12px}.quick-pick-time{color:var(--accent);font-size:22px;font-weight:500;line-height:1}.quick-pick-time span{color:var(--text2);margin-left:2px;font-size:12px;font-weight:400}.quick-pick-name{-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:6px;font-size:13px;line-height:1.3;display:-webkit-box;overflow:hidden}.tag-filter-row{scrollbar-width:none;gap:8px;padding:0 20px 14px;display:flex;overflow-x:auto}.tag-filter-row::-webkit-scrollbar{display:none}.tag-chip{background:var(--card);border:1px solid var(--border);color:var(--text2);white-space:nowrap;border-radius:100px;flex-shrink:0;padding:6px 14px;font-size:13px}.tag-chip.active{background:var(--accent-bg);border-color:var(--accent);color:var(--accent)}.recipe-list{padding-top:4px}.recipe-row{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:16px 20px;display:flex}.recipe-row:last-child{border-bottom:none}.recipe-row-body{text-align:left;min-width:0;color:inherit;background:0 0;border:none;flex:1;padding:0}.recipe-row-status{text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:4px;margin-bottom:4px;font-size:11px;font-weight:500;display:inline-flex}.recipe-row-status.status-progress{color:var(--accent)}.recipe-row-status.status-next{color:var(--green)}.recipe-row-name{margin-bottom:4px;font-size:17px;font-weight:500}.recipe-row-meta{color:var(--text2);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.recipe-row-meta .dot{color:var(--text3);margin:0 6px}.recipe-row-action{background:var(--accent-bg);width:38px;height:38px;color:var(--accent);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.cook-overlay{background:var(--bg);z-index:200;flex-direction:column;display:flex;position:fixed;inset:0;overflow-y:auto}.cook-header{align-items:center;gap:12px;padding:16px 20px 0;display:flex}.cook-title{flex:1;font-size:18px;font-weight:500}.cook-body{flex:1;padding:20px}.cook-footer{padding:16px 20px calc(16px + env(safe-area-inset-bottom));gap:12px;display:flex}.prep-item{border-bottom:1px solid var(--border);cursor:pointer;align-items:flex-start;gap:14px;padding:12px 0;display:flex}.prep-num{background:var(--accent-bg);width:28px;height:28px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:500;display:flex}.prep-num.done{background:var(--green-bg);color:var(--green)}.prep-text{flex:1;padding-top:3px}.prep-text.done{color:var(--text3);text-decoration:line-through}.prep-clean-prompt{background:var(--card);color:var(--text2);border-radius:10px;margin:8px 0;padding:10px 14px;font-size:13px}.step-progress{flex-wrap:wrap;gap:6px;padding:12px 20px;display:flex}.step-dot{background:var(--border);border-radius:50%;width:8px;height:8px;transition:background .2s}.step-dot.done{background:var(--accent)}.step-dot.current{background:var(--text)}.step-title{margin-bottom:10px;font-size:20px;font-weight:500}.step-instruction{font-size:16px;line-height:1.6}.step-detail{color:var(--text2);margin-top:8px;font-size:13px;line-height:1.5}.step-chefiq{background:var(--card);border:1px solid var(--border);color:var(--text2);border-radius:10px;margin-top:14px;padding:10px 14px;font-size:13px}.step-warning{background:var(--red-bg);color:var(--red);border-radius:10px;margin-top:10px;padding:10px 14px;font-size:13px}.step-clean{background:var(--accent-bg);color:var(--accent);border-radius:10px;margin-top:10px;padding:10px 14px;font-size:13px}.timer-box{background:var(--card);border:2px solid var(--border);text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:16px;margin-top:16px;padding:24px;transition:border-color .2s}.timer-box.running{border-color:var(--accent)}.timer-box.done{border-color:var(--green)}.timer-time{font-variant-numeric:tabular-nums;font-size:32px;font-weight:500}.timer-box.done .timer-time{color:var(--green)}.timer-label{color:var(--text2);text-transform:uppercase;letter-spacing:.5px;margin-top:4px;font-size:12px}.wake-badge{color:var(--accent);background:var(--accent-bg);border-radius:6px;padding:2px 8px;font-size:11px}.btn-nav{background:var(--card);border:1px solid var(--border);min-height:64px;color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:14px;flex:1;padding:18px;font-size:17px;font-weight:500}.btn-nav:active{opacity:.7}.btn-nav.accent{background:var(--accent-bg);border-color:var(--accent);color:var(--accent);flex:2}.pd-img{object-fit:contain;background:#ffffff08;border-radius:12px;width:100%;max-height:160px;margin-bottom:16px}.pd-section{margin-bottom:16px}.pd-section-label{color:var(--accent);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;font-size:11px;font-weight:600}.pd-row{border-bottom:.5px solid var(--border);justify-content:space-between;gap:12px;padding:6px 0;font-size:13px;display:flex}.pd-row:last-child{border-bottom:none}.pd-row-label{color:var(--text2)}.pd-row-val{color:var(--text);text-align:right}.pd-text{color:var(--text2);font-size:13px;line-height:1.6}.rd-meta{color:var(--text2);flex-wrap:wrap;gap:14px;margin-bottom:14px;font-size:13px;display:flex}.rd-meta-item{align-items:center;gap:5px;display:flex}.rd-meta-item svg{color:var(--accent)}.rd-prep-item{color:var(--text2);align-items:flex-start;gap:10px;padding:6px 0;font-size:13px;display:flex}.rd-prep-num{background:var(--accent-bg);width:20px;height:20px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;display:flex}.rd-step{border-bottom:.5px solid var(--border);padding:10px 0}.rd-step:last-child{border-bottom:none}.rd-step-highlight{background:var(--accent-bg);border-bottom:.5px solid #0000;border-radius:8px;margin:0 -20px;padding:10px 20px}.rd-step-title{margin-bottom:4px;font-size:14px;font-weight:500}.rd-step-instruction{color:var(--text2);font-size:13px;line-height:1.5}.rd-step-chefiq{color:var(--accent);margin-top:6px;font-size:12px}.rd-sticky-cta{background:var(--card);border-top:1px solid var(--border);margin-top:12px;padding-top:16px;position:sticky;bottom:0}
