@import"https://fonts.googleapis.com/css2?family=Nunito:ital,wght@0,400;0,500;0,600;0,700;0,800;1,500;1,600;1,700&family=Inter:wght@400;500;600;700&family=DM+Mono:wght@400;500;700&display=swap";:root{--bg: #FFF7EC;--bg-card: #FFFFFF;--bg2: #F5E6CC;--bg-2: #F5E6CC;--bg3: #E8D0A0;--bg-3: #E8D0A0;--ink: #1F1A17;--ink-2: #3D2F22;--ink-3: #8A7A6C;--ink-4: #B8A898;--text: #1F1A17;--text2: #3D2F22;--text3: #8A7A6C;--text4: #B8A898;--line: rgba(31,26,23,.16);--line-2: rgba(31,26,23,.09);--border: rgba(31,26,23,.16);--border2: rgba(31,26,23,.09);--green: #F9734A;--green-2: #FEE8DF;--green-ink: #C44E2B;--accent: #F9734A;--accent-light: #FEE8DF;--brand: #F9734A;--brand-soft: #FEE8DF;--brand-ink: #C44E2B;--terra: #7A4E2D;--terra-2: #F3D6AD;--accent2: #7A4E2D;--accent2-light: #F3D6AD;--success: #6DBE7E;--success-2: #DFF2E6;--success-ink: #2A7A48;--plum: #5A1E4C;--plum-2: #ECD2E4;--red: #C0392B;--red-2: #FDECEA;--red-light: #FDECEA;--amber: #D4850A;--amber-2: #FFF3CD;--blue: #1A5276;--blue-light: #D8E8F4;--r: 14px;--r-sm: 10px;--r-xs: 6px;--radius: 14px;--radius-sm: 10px;--shadow-1: 0 1px 3px rgba(31,26,23,.06), 0 4px 12px rgba(31,26,23,.06);--shadow-2: 0 2px 8px rgba(31,26,23,.1), 0 14px 32px rgba(31,26,23,.12);--shadow: 0 1px 3px rgba(31,26,23,.06), 0 4px 12px rgba(31,26,23,.06);--shadow-md: 0 2px 8px rgba(31,26,23,.1), 0 14px 32px rgba(31,26,23,.12);--serif: "Nunito", system-ui, sans-serif;--sans: "Inter", "Nunito", system-ui, sans-serif;--mono: "DM Mono", ui-monospace, monospace;--header-h: 61px;--sidebar-w: 240px;--sb-h: 0px}[data-theme=dark]{--bg: #1C1612;--bg-card: #262018;--bg-2: #302820;--bg-3: #3E3226;--bg2: #302820;--bg3: #3E3226;--ink: #F0EBE0;--ink-2: #C8BCA8;--ink-3: #8A7A6C;--ink-4: #5A4E42;--text: #F0EBE0;--text2: #C8BCA8;--text3: #8A7A6C;--text4: #5A4E42;--line: rgba(240,235,224,.14);--line-2: rgba(240,235,224,.08);--border: rgba(240,235,224,.14);--border2: rgba(240,235,224,.08);--green: #F9734A;--green-2: #402014;--green-ink: #FFCBB8;--brand: #F9734A;--brand-soft: #402014;--brand-ink: #FFCBB8;--terra: #C08850;--terra-2: #3A2410;--success: #5AAA6C;--success-2: #1A3020;--success-ink: #A0D4A8;--plum: #B06898;--plum-2: #2C1428;--red: #D44A30;--red-2: #3A1410;--red-light: #3A1410;--amber: #D4A030;--amber-2: #3A2A08;--shadow-1: 0 1px 2px rgba(0,0,0,.3), 0 2px 8px rgba(0,0,0,.3);--shadow-2: 0 2px 6px rgba(0,0,0,.4), 0 12px 28px rgba(0,0,0,.4);--shadow: 0 1px 2px rgba(0,0,0,.3), 0 2px 8px rgba(0,0,0,.3)}[data-theme=warm],[data-theme=light]{--bg: #FFF7EC;--bg-card: #FFFFFF;--bg-2: #F5E6CC;--bg-3: #E8D0A0;--bg2: #F5E6CC;--bg3: #E8D0A0;--ink: #1F1A17;--ink-2: #3D2F22;--ink-3: #8A7A6C;--ink-4: #B8A898;--text: #1F1A17;--text2: #3D2F22;--text3: #8A7A6C;--text4: #B8A898;--line: rgba(31,26,23,.16);--line-2: rgba(31,26,23,.09);--border: rgba(31,26,23,.16);--border2: rgba(31,26,23,.09);--green: #F9734A;--green-2: #FEE8DF;--green-ink: #C44E2B;--accent: #F9734A;--accent-light: #FEE8DF;--brand: #F9734A;--brand-soft: #FEE8DF;--brand-ink: #C44E2B;--terra: #7A4E2D;--terra-2: #F3D6AD;--accent2: #7A4E2D;--accent2-light: #F3D6AD;--success: #6DBE7E;--success-2: #DFF2E6;--success-ink: #2A7A48;--plum: #5A1E4C;--plum-2: #ECD2E4;--red: #C0392B;--red-2: #FDECEA;--red-light: #FDECEA;--amber: #D4850A;--amber-2: #FFF3CD;--shadow-1: 0 1px 3px rgba(31,26,23,.06), 0 4px 12px rgba(31,26,23,.06);--shadow-2: 0 2px 8px rgba(31,26,23,.1), 0 14px 32px rgba(31,26,23,.12);--shadow: 0 1px 3px rgba(31,26,23,.06), 0 4px 12px rgba(31,26,23,.06);--shadow-md: 0 2px 8px rgba(31,26,23,.1), 0 14px 32px rgba(31,26,23,.12)}[data-theme=calm]{--bg: #FAF7F2;--bg-card: #FFFFFF;--bg-2: #FFF9F1;--bg-3: #F6EFE5;--bg2: #FFF9F1;--bg3: #F6EFE5;--ink: #1F1A17;--ink-2: #3D2F22;--ink-3: #7D7167;--ink-4: #B8A898;--text: #1F1A17;--text2: #3D2F22;--text3: #7D7167;--text4: #B8A898;--line: #E8D8C5;--line-2: rgba(232,216,197,.65);--border: #E8D8C5;--border2: rgba(232,216,197,.65);--green: #E85D3F;--brand: #E85D3F;--brand-soft: #FEF2EE;--brand-ink: #D94F35;--green-2: #FEF2EE;--green-ink: #D94F35;--accent: #E85D3F;--accent-light: #FEF2EE;--terra: #6B4428;--terra-2: #EFD2A8;--accent2: #6B4428;--accent2-light: #EFD2A8;--success: #5FAE73;--success-2: #DDEDDD;--success-ink: #2E7A48;--plum: #5A1E4C;--plum-2: #ECD2E4;--red: #C0392B;--red-2: #FDECEA;--red-light: #FDECEA;--amber: #D4850A;--amber-2: #FFF3CD;--shadow-1: 0 1px 3px rgba(31,26,23,.04), 0 4px 12px rgba(31,26,23,.04);--shadow-2: 0 2px 8px rgba(31,26,23,.07), 0 14px 32px rgba(31,26,23,.09);--shadow: 0 1px 3px rgba(31,26,23,.04), 0 4px 12px rgba(31,26,23,.04);--shadow-md: 0 2px 8px rgba(31,26,23,.07), 0 14px 32px rgba(31,26,23,.09)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;overscroll-behavior-x:none;overscroll-behavior-y:none;background:var(--bg-2)}body{font-family:var(--sans);background:var(--bg);color:var(--ink);min-height:100%;font-size:15px;line-height:1.6;font-weight:500;-webkit-font-smoothing:antialiased;overscroll-behavior-x:none;overscroll-behavior-y:none;margin:0}#root{min-height:100%}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea,select{font-family:inherit}ul{list-style:none}a{color:inherit;text-decoration:none}.auth-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%);display:flex;align-items:center;justify-content:center;padding:24px}.auth-box{background:var(--bg-card);border:1px solid var(--line);border-radius:22px;padding:40px 36px;width:100%;max-width:420px;box-shadow:var(--shadow-2)}.auth-logo{margin-bottom:10px;display:flex;align-items:center}.auth-subtitle{font-size:14px;color:var(--ink-2);margin-bottom:28px;line-height:1.5}.auth-tabs{display:flex;gap:0;background:var(--bg-2);border-radius:999px;padding:4px;margin-bottom:24px}.auth-tab{flex:1;padding:9px;text-align:center;border-radius:999px;font-size:14px;font-weight:600;cursor:pointer;color:var(--ink-3);border:none;background:none;font-family:inherit;transition:all .18s}.auth-tab.active{background:var(--bg-card);color:var(--ink);box-shadow:0 1px 3px #00000014}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:11px;font-weight:700;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;font-family:var(--mono)}.field input{width:100%;padding:11px 14px;border:1px solid var(--line);border-radius:var(--r-sm);font-size:14px;font-family:inherit;background:var(--bg-card);color:var(--ink);transition:border-color .15s;outline:none}.field input:focus{border-color:var(--green);box-shadow:0 0 0 3px #f9734a24}.field input:-webkit-autofill,.field input:-webkit-autofill:hover,.field input:-webkit-autofill:focus,.field input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 40px var(--bg-card) inset!important;-webkit-text-fill-color:var(--ink)!important;caret-color:var(--ink);border-color:var(--line)}.auth-btn{width:100%;padding:13px;background:var(--green);color:#fff;border:none;border-radius:999px;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;margin-top:6px;letter-spacing:.01em;transition:background .15s,transform .1s}.auth-btn:hover{background:var(--green-ink)}.auth-btn:active{transform:scale(.98)}.auth-btn:disabled{opacity:.45;cursor:not-allowed}.auth-divider{display:flex;align-items:center;gap:12px;margin:18px 0;color:var(--ink-3);font-size:12px;text-transform:uppercase;letter-spacing:.08em}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--line-2)}.google-btn{width:100%;padding:12px;background:var(--bg-card);color:var(--ink);border:1px solid var(--line);border-radius:14px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:background .15s}.google-btn:hover{background:var(--bg-2)}.auth-error{color:var(--red);font-size:13px;margin-top:10px;padding:10px 12px;background:var(--red-2);border-radius:var(--r-sm)}.auth-footer-note{text-align:center;font-size:12px;color:var(--ink-3);margin-top:18px}.auth-footer-note a,.auth-box a{color:var(--terra);text-decoration:underline;font-weight:600}.auth-box a:hover{color:var(--plum)}.app-layout{display:flex;min-height:100dvh;overflow-x:clip}.app-main{flex:1;display:flex;flex-direction:column;min-height:100dvh;max-width:480px;margin:0 auto;width:100%;min-width:0;padding-bottom:calc(60px + max(8px,env(safe-area-inset-bottom,8px)))}.app-sidebar{display:none;flex-direction:column;position:fixed;left:0;top:0;width:var(--sidebar-w);height:100%;background:var(--bg-2);border-right:1px solid var(--line-2);padding:0 14px 24px;z-index:200;overflow-y:auto}.sidebar-logo{padding:20px 10px 4px;flex-shrink:0}.sidebar-tagline{font-size:11px;color:var(--ink-3);padding:4px 10px 16px;line-height:1.4;letter-spacing:.005em}.sidebar-section{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);font-weight:500;padding:12px 10px 6px}.sidebar-nav{display:flex;flex-direction:column;gap:2px;flex:1}.g-nav-btn{display:flex;align-items:center;gap:12px;padding:10px 12px;border:none;border-radius:10px;background:none;cursor:pointer;font-size:14px;font-weight:500;color:var(--ink-2);font-family:inherit;width:100%;transition:background .15s;text-align:left}.g-nav-btn:hover{background:var(--bg-3)}.g-nav-btn.active{background:var(--bg-card);color:var(--ink);box-shadow:var(--shadow-1)}.g-nav-btn .nav-icon{display:inline-flex;color:var(--ink-3);flex-shrink:0}.g-nav-btn.active .nav-icon{color:var(--green)}.g-nav-count{margin-left:auto;background:var(--green);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:999px;min-width:18px;text-align:center}.sidebar-user{display:flex;align-items:center;gap:10px;padding:10px;border-radius:10px;background:var(--bg-card);border:1px solid var(--line-2);margin-top:auto}.sidebar-user-name{font-size:13px;font-weight:600}.sidebar-user-email{font-size:11px;color:var(--ink-3);font-family:var(--mono)}header.app-header{position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--bg) 92%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line-2);padding:14px 20px;display:flex;align-items:center;gap:12px}.app-logo{display:inline-flex;align-items:center;gap:6px;flex:1}.header-icon-btn{width:36px;height:36px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:var(--bg-2);color:var(--ink-2);border:none;cursor:pointer;transition:background .15s;position:relative}.header-icon-btn:hover{background:var(--bg-3)}.header-badge-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:50%;background:var(--terra);border:2px solid var(--bg)}.user-btn{width:34px;height:34px;border-radius:50%;background:var(--green-2);color:var(--green-ink);cursor:pointer;overflow:hidden;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:14px;font-weight:700;border:2px solid var(--bg-card);box-shadow:var(--shadow-1)}.user-btn img{width:100%;height:100%;object-fit:cover;border-radius:50%}.lang-wrap{display:flex;align-items:center;gap:7px}.lang-lbl{font-size:11px;font-weight:600;color:var(--ink-3)}.lang-lbl.on{color:var(--green)}.lang-track{width:38px;height:20px;border-radius:999px;background:var(--bg-3);border:1px solid var(--line);cursor:pointer;position:relative}.lang-track.zh{background:var(--green);border-color:var(--green)}.lang-thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:var(--ink-3);transition:transform .22s cubic-bezier(.34,1.56,.64,1),background .2s}.lang-track.zh .lang-thumb{transform:translate(18px);background:#fff}.tab-bar{display:flex;border-bottom:1px solid var(--line-2);background:color-mix(in srgb,var(--bg) 95%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:sticky;top:var(--header-h);z-index:90}.tab-btn{flex:1;padding:12px 2px;font-size:10px;font-weight:700;border:none;background:none;cursor:pointer;color:var(--ink-3);letter-spacing:.06em;text-transform:uppercase;font-family:var(--mono);border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .15s}.tab-btn.active{color:var(--green);border-bottom-color:var(--green)}.tab-content{display:flex;padding:20px;flex-direction:column;gap:20px}.eyebrow{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);font-weight:600}.section-label{display:flex;align-items:center;justify-content:space-between;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);font-weight:500;margin-bottom:10px}.card{background:var(--bg-card);border:1px solid var(--line-2);border-radius:var(--r);padding:16px;box-shadow:var(--shadow-1)}.h1-serif{font-family:var(--serif);font-weight:600;font-size:26px;line-height:1.2;letter-spacing:-.01em;color:var(--ink)}.h1-serif em{font-style:normal;font-weight:700}.h2-serif{font-family:var(--serif);font-weight:600;font-size:20px;line-height:1.25;letter-spacing:-.005em}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:var(--bg-2);color:var(--ink-2);font-size:12px;font-weight:600;border:1px solid transparent;transition:all .15s;cursor:pointer;white-space:nowrap}.chip.on{background:var(--green-2);color:var(--green-ink);border-color:#f9734a47}.chip.warn{background:var(--amber-2);color:var(--amber);border-color:#8c610a33}.chip.danger{background:var(--red-2);color:var(--red);border-color:#a1240e33}.chip.terra{background:var(--terra-2);color:var(--terra);border-color:#a1401233}.chip.plum{background:var(--plum-2);color:var(--plum);border-color:#5a1e4c33}.pill{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:600;border:1px solid transparent}.pill-green{background:var(--success-2);color:var(--success-ink)}.pill-amber{background:var(--amber-2);color:var(--amber)}.pill-terra{background:var(--terra-2);color:var(--terra)}.pill-red{background:var(--red-2);color:var(--red)}.pill-plum{background:var(--plum-2);color:var(--plum)}.pill.safe{background:var(--success-2);color:var(--success-ink);border-color:#6dbe7e4d}.pill.urgent{background:var(--terra-2);color:var(--terra);border-color:#a1401233}.pill.missing{background:var(--red-2);color:var(--red);border-color:#a1240e33}.pills{display:flex;flex-wrap:wrap;gap:6px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;border-radius:14px;font-weight:700;font-size:14px;font-family:inherit;transition:transform .1s,background .18s,opacity .18s;cursor:pointer;border:none}.btn-primary{background:var(--green);color:#fff;border-radius:999px;letter-spacing:.01em}.btn-primary:hover{background:var(--green-ink)}.btn-primary:active{transform:scale(.98)}.btn-ghost{background:var(--bg-2);color:var(--ink)}.btn-ghost:hover{background:var(--bg-3)}.btn-outline{background:transparent;border:1px solid var(--line);color:var(--ink)}.btn-outline:hover{background:var(--bg-2)}.btn-full{width:100%;padding:13px;font-size:15px;font-weight:700}.btn-sm{padding:8px 14px;font-size:13px;border-radius:10px}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{background:var(--bg-2);color:var(--ink);border:1px solid var(--line-2)}.btn-secondary:hover{background:var(--bg-3)}.meter{position:relative;height:4px;background:var(--bg-2);border-radius:999px;overflow:hidden}.meter-fill{position:absolute;top:0;left:0;bottom:0;background:var(--green);border-radius:999px;transition:width .5s cubic-bezier(.4,1.4,.6,1)}.meter-fill.warn{background:var(--amber)}.meter-fill.low{background:var(--terra)}.ph{background:repeating-linear-gradient(135deg,#0e0c080a 0,#0e0c080a 6px,#0e0c0812 6px,#0e0c0812 12px);color:var(--ink-3);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;overflow:hidden;position:relative}.ph.tone-green{background:repeating-linear-gradient(135deg,#6dbe7e1f 0,#6dbe7e1f 6px,#6dbe7e38 6px,#6dbe7e38 12px);color:var(--success-ink)}.ph.tone-terra{background:repeating-linear-gradient(135deg,#b85b231a 0,#b85b231a 6px,#b85b232e 6px,#b85b232e 12px);color:var(--terra)}.ph.tone-plum{background:repeating-linear-gradient(135deg,#6b2c5c1a 0,#6b2c5c1a 6px,#6b2c5c2e 6px,#6b2c5c2e 12px);color:var(--plum)}.ph.tone-amber{background:repeating-linear-gradient(135deg,#8c610a1a 0,#8c610a1a 6px,#8c610a2e 6px,#8c610a2e 12px);color:var(--amber)}.ph.tone-warm{background:repeating-linear-gradient(135deg,#a140120f 0,#a140120f 6px,#8c610a1a 6px,#8c610a1a 12px);color:var(--terra)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0e0c0873;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:flex-end;justify-content:center;z-index:400;padding:0}.modal-box,.sheet{background:var(--bg-card);border-radius:22px 22px 0 0;width:100%;max-width:480px;display:flex;flex-direction:column;max-height:88vh;box-shadow:0 -10px 40px #0000002e;animation:sheetUp .28s cubic-bezier(.2,.9,.3,1) both}@keyframes sheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-box{padding:22px;overflow-y:auto}.modal-box h3{font-family:var(--serif);font-size:17px;font-weight:600}.sheet-handle{width:36px;height:4px;background:var(--ink-4);border-radius:999px;margin:8px auto 4px;opacity:.5}.sheet-head{display:flex;align-items:center;gap:10px;padding:10px 18px 14px;border-bottom:1px solid var(--line-2)}.sheet-head h3{flex:1;font-family:var(--serif);font-size:19px;font-weight:700;letter-spacing:-.01em}.sheet-body{overflow-y:auto;padding:16px 18px 24px}.sheet-footer{padding:12px 18px 18px;border-top:1px solid var(--line-2)}.toast-host{position:fixed;left:0;right:0;bottom:88px;display:flex;justify-content:center;pointer-events:none;z-index:500}.toast{background:var(--ink);color:#fbfaf6;padding:10px 16px;border-radius:999px;font-size:13px;font-weight:600;box-shadow:var(--shadow-2);animation:toastIn .25s ease both;display:inline-flex;align-items:center;gap:8px}@keyframes toastIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--bg-card);border-top:1px solid var(--line-2);box-shadow:0 -1px 0 var(--line-2),0 -4px 24px #1f1a1712;display:grid;grid-template-columns:repeat(5,1fr);z-index:200;padding:0 4px max(0px,env(safe-area-inset-bottom,0px))}.nav-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;height:60px;padding:0 2px;color:var(--ink-3);font-size:9px;font-weight:600;letter-spacing:.04em;font-family:var(--mono);border-radius:8px;background:none;border:none;cursor:pointer;position:relative;transition:color .15s}.nav-btn .bn-ico{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;transition:transform .15s}.nav-btn.active .bn-ico svg{stroke-width:2.5}.nav-btn.active{color:var(--green)}.nav-btn.active .bn-ico{transform:scale(1.08)}.nb-wrap{position:relative;display:inline-flex}.nb-count{position:absolute;top:-4px;right:-6px;background:var(--terra);color:#fff;font-size:9px;font-weight:700;border-radius:999px;min-width:14px;height:14px;padding:0 3px;display:inline-flex;align-items:center;justify-content:center}@media (min-width: 480px){.nav-btn{height:64px;font-size:10px}.nav-btn .bn-ico{width:26px;height:26px}}.ing-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(88px,1fr));gap:8px}.ing-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 4px 8px;border-radius:var(--r);border:1.5px solid transparent;background:var(--bg-2);cursor:pointer;position:relative;transition:border-color .15s,background .15s,transform .1s;-webkit-user-select:none;user-select:none}.ing-card:hover{transform:translateY(-1px)}.ing-card.selected{border-color:var(--green);background:var(--green-2)}.ing-card.selected .ing-lbl{color:var(--green-ink)}.ing-em{font-size:26px}.ing-lbl{font-size:10px;font-weight:600;color:var(--ink-2);text-align:center;line-height:1.3;font-family:var(--mono)}.pet-warn{position:absolute;top:3px;left:3px;font-size:10px;line-height:1;background:var(--red-2);border:.5px solid rgba(161,36,14,.35);border-radius:4px;padding:1px 3px}.diet-warn{position:absolute;bottom:3px;left:3px;font-size:10px;line-height:1;background:var(--amber-2);border:.5px solid rgba(140,97,10,.35);border-radius:4px;padding:1px 3px}.ai-dot{position:absolute;top:3px;right:3px;width:13px;height:13px;background:var(--blue);border-radius:50%;font-size:7px;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}.ing-card-group{border-style:dashed;border-color:var(--line-2)}.ing-card-group:hover{border-color:var(--green)}.ing-card-group.selected{border-style:solid}.ing-expand-row{display:flex;align-items:center;justify-content:center;height:14px}.ing-chevron{font-size:12px;color:var(--ink-3);line-height:1}.ing-child-count{font-size:10px;font-weight:700;color:#fff;background:var(--green);border-radius:999px;padding:1px 6px;line-height:1.5}.sub-selector-sheet{background:var(--bg);border-radius:20px 20px 0 0;padding:20px 20px 32px;width:100%;max-height:80vh;overflow-y:auto;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 32px #00000024;animation:slideUp .22s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sub-selector-header{display:flex;align-items:center;justify-content:space-between;font-family:var(--serif);font-size:18px;font-weight:700;color:var(--ink);margin-bottom:4px}.sub-selector-close{background:var(--bg-2);border:none;border-radius:50%;width:28px;height:28px;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-2);flex-shrink:0}.sub-selector-hint{font-size:12px;color:var(--ink-3);margin-bottom:14px}.sub-check{position:absolute;top:3px;right:3px;width:14px;height:14px;border-radius:50%;background:var(--green);color:#fff;font-size:8px;font-weight:700;display:flex;align-items:center;justify-content:center}.diet-grid{display:flex;flex-wrap:wrap;gap:8px}.diet-toggle{padding:6px 12px;border-radius:999px;border:1px solid var(--line-2);background:var(--bg-2);font-size:12px;font-weight:600;color:var(--ink-2);cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .15s}.diet-toggle.on{background:var(--green-2);border-color:#f9734a59;color:var(--green-ink)}.camera-panel{background:var(--bg-2);border-radius:var(--r);border:1px solid var(--line-2);overflow:hidden}.cam-mode-bar{display:flex;border-bottom:1px solid var(--line-2)}.cam-mode-btn{flex:1;padding:10px 4px;font-size:12px;font-weight:700;background:none;border:none;cursor:pointer;color:var(--ink-3);border-bottom:2px solid transparent;margin-bottom:-1px;letter-spacing:.04em;font-family:var(--mono)}.cam-mode-btn.active{color:var(--green);border-bottom-color:var(--green)}.drop-zone{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px;cursor:pointer}.drop-zone p{font-size:12px;color:var(--ink-3);text-align:center}.drop-zone-upload{font-size:11px;padding:6px 14px;border-radius:999px;border:1px solid var(--green);color:var(--green);background:var(--green-2);cursor:pointer;font-weight:600}.scan-preview{width:100%;max-height:160px;object-fit:cover}.scan-result{padding:10px 14px;font-size:13px;color:var(--ink-2);line-height:1.6;border-top:1px solid var(--line-2)}.scanning-ind{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;font-size:13px;color:var(--ink-2)}.recipe-card{background:var(--bg-card);border:1px solid var(--line-2);border-radius:18px;overflow:hidden;cursor:pointer;position:relative;transition:box-shadow .15s,transform .15s;box-shadow:var(--shadow-1);display:flex;flex-direction:column}.recipe-card:hover{box-shadow:var(--shadow-2);transform:translateY(-1px)}.recipe-card-img{position:relative;width:100%;height:160px;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center}.recipe-card-body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:6px;flex:1}.recipe-card h3{font-family:var(--serif);font-size:19px;font-weight:700;color:var(--ink);margin-bottom:4px;line-height:1.25;letter-spacing:-.01em}.heart-btn{position:absolute;top:10px;right:10px;width:32px;height:32px;border-radius:999px;background:#fffdf8f0;border:none;color:var(--ink-2);cursor:pointer;z-index:2;display:inline-flex;align-items:center;justify-content:center;box-shadow:var(--shadow-1)}.recipe-hero{width:100%;height:220px;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;position:relative}.badge{font-size:11px;padding:3px 9px;border-radius:999px;font-weight:700;display:inline-block}.badge.easy{background:var(--success-2);color:var(--success-ink)}.badge.medium{background:var(--amber-2);color:var(--amber)}.badge.hard{background:var(--red-2);color:var(--red)}.badge.urgent{background:var(--terra-2);color:var(--terra)}.badge.treat{background:var(--blue-light);color:var(--blue)}.badge.dog{background:var(--terra-2);color:var(--terra)}.badge.cat{background:var(--plum-2);color:var(--plum)}.badge.meal{background:var(--success-2);color:var(--success-ink)}.pet-switcher{display:flex;background:var(--bg-2);border-radius:999px;padding:4px;gap:4px}.pet-sw{flex:1;padding:8px 12px;border-radius:999px;border:none;font-size:13px;font-weight:700;cursor:pointer;background:none;color:var(--ink-3);font-family:inherit;transition:all .18s}.pet-sw.active{background:var(--bg-card);color:var(--ink);box-shadow:0 1px 4px #0000001a}.pet-action-row{display:flex;gap:10px}.btn-treat{flex:1;padding:13px;font-size:14px;font-weight:700;border:none;border-radius:14px;cursor:pointer;background:var(--terra);color:#fdf0e0;font-family:inherit}.btn-treat:hover{background:#8a3010}.btn-meal-pet{flex:1;padding:13px;font-size:14px;font-weight:700;border:none;border-radius:14px;cursor:pointer;background:var(--green);color:#e0f5ec;font-family:inherit}.btn-meal-pet:hover{background:var(--green-ink)}.toxic-warning{background:var(--red-2);border:1px solid rgba(161,36,14,.25);border-radius:var(--r-sm);padding:12px 14px;font-size:13px;color:var(--red);line-height:1.6}.safe-ing-box{background:var(--success-2);border:1px solid rgba(109,190,126,.28);border-radius:var(--r-sm);padding:12px 14px;font-size:13px;color:var(--success-ink);line-height:1.6}.pet-portion{background:var(--bg-2);border-radius:var(--r-sm);padding:10px 14px;font-size:13px;color:var(--ink-2)}.ext-panel{background:var(--bg-2);border-radius:var(--r);border:1px solid var(--line-2);overflow:hidden}.ext-tab-bar{display:flex;border-bottom:1px solid var(--line-2)}.ext-tab{flex:1;padding:10px 4px;font-size:12px;font-weight:700;background:none;border:none;cursor:pointer;color:var(--ink-3);border-bottom:2px solid transparent;margin-bottom:-1px;letter-spacing:.04em;font-family:var(--mono)}.ext-tab.active{color:var(--green);border-bottom-color:var(--green)}.ext-body{padding:16px;display:flex;flex-direction:column;gap:10px}.url-row{display:flex;gap:8px}.url-row input{flex:1;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r-sm);font-size:13px;font-family:inherit;background:var(--bg-card);outline:none}.url-row input:focus{border-color:var(--green)}.url-row button{padding:10px 16px;background:var(--green);color:#fff;border:none;border-radius:var(--r-sm);font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap}.file-drop{border:1.5px dashed var(--line-2);border-radius:var(--r-sm);padding:22px 16px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:border-color .15s,background .15s}.file-drop.drag-over{border-color:var(--green);background:var(--green-2)}.file-drop p{font-size:12px;color:var(--ink-3);text-align:center}.ext-result{background:var(--bg-card);border:1px solid var(--line-2);border-radius:var(--r-sm);padding:14px;display:flex;flex-direction:column;gap:12px}.ext-error{font-size:13px;color:var(--red);padding:10px 12px;background:var(--red-2);border-radius:var(--r-sm)}.ext-loading{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px;font-size:13px;color:var(--ink-2)}.ext-recipe-title{font-family:var(--serif);font-size:16px;font-weight:700}.ext-section-lbl{font-size:11px;font-weight:700;color:var(--ink-3);letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px;font-family:var(--mono)}.ext-step{font-size:13px;color:var(--ink);line-height:1.6;padding:8px 12px;background:var(--bg-2);border-radius:var(--r-sm)}.preview-img{width:100%;max-height:180px;object-fit:cover;border-radius:var(--r-sm)}.day-row{background:var(--bg-card);border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-1)}.day-hdr{padding:11px 16px;background:var(--bg-2);font-size:13px;font-weight:700;color:var(--ink)}.meal-slot{padding:10px 16px;display:flex;align-items:center;gap:8px;border-top:1px solid var(--line-2);flex-wrap:wrap}.meal-type{font-size:11px;color:var(--ink-3);font-weight:700;width:56px;flex-shrink:0;letter-spacing:.04em;text-transform:uppercase;font-family:var(--mono)}.meal-name{flex:1;font-size:13px;color:var(--ink)}.meal-empty{flex:1;font-size:13px;color:var(--ink-3);font-style:italic}.add-meal-btn{font-size:11px;padding:5px 12px;border-radius:999px;border:1px solid var(--line);background:var(--bg-2);color:var(--ink-2);cursor:pointer;font-weight:600;font-family:inherit}.rm-btn{background:none;border:none;font-size:13px;color:var(--ink-3);cursor:pointer}.srv-ctrl{display:flex;align-items:center;gap:8px}.srv-b{width:24px;height:24px;border-radius:50%;border:1px solid var(--line);background:var(--bg-2);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;color:var(--ink-2)}.srv-b:hover{background:var(--green-2);border-color:var(--green)}.srv-v{font-size:13px;font-weight:700;min-width:18px;text-align:center}.cart-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--line-2)}.cart-item:last-child{border-bottom:none}.cart-check{width:22px;height:22px;border-radius:7px;border:1.5px solid var(--line);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center}.cart-check.checked{background:var(--green);border-color:var(--green);color:#fff}.cart-name{flex:1;font-size:14px;font-weight:500}.cart-name.done{text-decoration:line-through;color:var(--ink-3)}.cart-del{background:none;border:none;color:var(--ink-3);cursor:pointer;font-size:15px;padding:4px}.cart-sec-lbl{font-size:11px;font-weight:700;color:var(--ink-3);letter-spacing:.06em;text-transform:uppercase;padding:4px 0;border-bottom:1px solid var(--line-2);margin-bottom:4px;font-family:var(--mono)}@media (min-width: 640px) and (max-width: 1023px){.grocery-list-container{max-width:720px;margin:0 auto}}@media (min-width: 1024px){.grocery-list-container{max-width:900px;margin:0 auto;column-count:2;column-gap:18px}.grocery-list-container>div{break-inside:avoid}}.stor-card{background:var(--bg-card);border:1px solid var(--line-2);border-radius:var(--r);padding:16px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow-1)}.stor-loc{display:inline-flex;align-items:center;font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px;letter-spacing:.04em;white-space:nowrap;font-family:var(--mono)}.loc-fridge{background:var(--blue-light);color:var(--blue)}.loc-pantry{background:var(--green-2);color:var(--green-ink)}.loc-counter{background:var(--terra-2);color:var(--terra)}.stor-tip{font-size:13px;color:var(--ink-2);line-height:1.65;border-left:2px solid var(--line-2);padding-left:12px}.stor-edit-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.stor-edit-label{font-size:12px;color:var(--ink-2);width:56px;flex-shrink:0}.avatar-lg{width:80px;height:80px;border-radius:50%;background:var(--bg-2);border:2px solid var(--line-2);display:flex;align-items:center;justify-content:center;font-size:36px;cursor:pointer;overflow:hidden}.avatar-lg img{width:100%;height:100%;object-fit:cover;border-radius:50%}.pet-profile-card{background:var(--bg-2);border-radius:var(--r);padding:14px;display:flex;align-items:center;gap:14px}.pet-av{width:50px;height:50px;border-radius:50%;background:var(--bg-card);border:1.5px solid var(--line-2);display:flex;align-items:center;justify-content:center;font-size:24px;cursor:pointer;overflow:hidden;flex-shrink:0}.pet-av img{width:100%;height:100%;object-fit:cover;border-radius:50%}.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.stat-card{background:var(--bg-2);border-radius:var(--r-sm);padding:14px;text-align:center}.stat-v{font-size:24px;font-weight:700;color:var(--green);font-family:var(--serif)}.stat-l{font-size:11px;color:var(--ink-3);margin-top:2px;font-weight:600;font-family:var(--mono)}.saved-card{background:var(--bg-card);border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;cursor:pointer;box-shadow:var(--shadow-1);position:relative}.saved-card-img{width:100%;aspect-ratio:16/9;background:repeating-linear-gradient(45deg,var(--bg-2) 0,var(--bg-2) 5px,var(--bg-3) 5px,var(--bg-3) 10px);display:flex;align-items:center;justify-content:center;font-size:36px;overflow:hidden;flex-shrink:0}.saved-card-img img{width:100%;height:100%;object-fit:cover;object-position:center 60%}.saved-card-body{padding:10px 12px 12px;flex:1;display:flex;flex-direction:column}.saved-card-bm{position:absolute;top:8px;right:8px;background:#00000052;border-radius:999px;padding:5px;display:flex;align-items:center;justify-content:center}.detail-header{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--line-2);position:sticky;top:0;background:color-mix(in srgb,var(--bg) 96%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:80}.detail-header h2{font-family:var(--serif);font-size:17px;font-weight:700;flex:1;letter-spacing:-.01em}.detail-body{padding:20px;display:flex;flex-direction:column;gap:16px}.tip-box{background:var(--terra-2);border-radius:var(--r-sm);padding:12px 14px;font-size:13px;color:var(--terra);line-height:1.65}.steps-list ol{padding-left:20px;display:flex;flex-direction:column;gap:10px}.steps-list li{font-size:14px;line-height:1.7}.profile-input{width:100%;background:var(--bg-card);border:1px solid var(--line);border-radius:10px;padding:12px 14px;font-size:14px;color:var(--ink);font-family:inherit;outline:none;transition:border .15s}.profile-input:focus{border-color:var(--green)}.form-field{margin-bottom:10px}.form-field-label{font-size:11px;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);font-weight:600;margin-bottom:6px}.row{display:flex;align-items:center;gap:10px}.row-between{display:flex;align-items:center;justify-content:space-between;gap:10px}.grow{flex:1;min-width:0}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.muted{color:var(--ink-3)}.stack>*+*{margin-top:14px}.scroll-row{display:flex;gap:10px;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;padding:2px 18px 6px;touch-action:pan-x pinch-zoom;-webkit-overflow-scrolling:touch;will-change:scroll-position}.scroll-row::-webkit-scrollbar{display:none}.chip-scroll-row{display:flex;gap:8px;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;touch-action:pan-x pinch-zoom;-webkit-overflow-scrolling:touch;will-change:scroll-position;padding-bottom:8px;min-width:0;flex-wrap:nowrap}.chip-scroll-row>*{flex-shrink:0}.chip-scroll-row::-webkit-scrollbar{display:none}.add-row{display:flex;gap:8px}.add-row input{flex:1;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r-sm);font-size:14px;font-family:inherit;background:var(--bg-card);outline:none}.add-row input:focus{border-color:var(--green)}.add-row button{padding:10px 14px;background:var(--green);color:#fff;border:none;border-radius:var(--r-sm);font-size:14px;font-weight:700;cursor:pointer;font-family:inherit}.sel-item{background:var(--bg-card);border:1px solid var(--line-2);border-radius:var(--r-sm);padding:10px 14px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.sel-item .nm{font-size:13px;font-weight:600;flex:1;min-width:80px}.expiry-btns{display:flex;gap:4px}.exp-btn{font-size:11px;padding:4px 9px;border-radius:999px;border:1px solid var(--line);cursor:pointer;background:var(--bg-2);color:var(--ink-2);font-family:inherit}.exp-btn.fine.active{background:var(--green-2);border-color:#f9734a59;color:var(--green-ink)}.exp-btn.soon.active{background:var(--terra-2);border-color:#a140124d;color:var(--terra)}.exp-btn.expired.active{background:var(--red-2);border-color:#a1240e4d;color:var(--red)}.fchip{font-size:11px;padding:4px 10px;border-radius:999px;border:1px solid var(--line);background:var(--bg-2);cursor:pointer;color:var(--ink-2);font-weight:600}.fchip.on{background:var(--green-2);border-color:#f9734a59;color:var(--green-ink)}.empty-state{text-align:center;padding:40px 20px;color:var(--ink-3);font-size:14px;line-height:1.8}.spinner{width:26px;height:26px;border:2px solid var(--line-2);border-top-color:var(--green);border-radius:50%;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-state{display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px 20px;color:var(--ink-2);font-size:14px}.divider{border:none;border-top:1px solid var(--line-2)}@keyframes skeletonPulse{0%,to{opacity:1}50%{opacity:.45}}.skeleton-pulse{animation:skeletonPulse 1.4s ease-in-out infinite}@keyframes fridgeWiggle{0%{transform:rotate(-1.5deg)}25%{transform:rotate(1.5deg)}50%{transform:rotate(-1deg)}75%{transform:rotate(1deg)}to{transform:rotate(-1.5deg)}}.fridge-card-wiggle{animation:fridgeWiggle .55s ease-in-out infinite;transform-origin:center}.filter-bar{display:flex;gap:6px;flex-wrap:wrap;padding:10px 0}.info-box{background:var(--bg-2);border-radius:var(--r-sm);padding:12px 14px;font-size:13px;color:var(--ink-2);line-height:1.6}.serving-box{background:var(--bg-2);border-radius:var(--r);padding:14px;display:flex;flex-direction:column;gap:12px}.srv-ctrl-lg{display:flex;align-items:center;gap:14px}.srv-btn-lg{width:32px;height:32px;border-radius:50%;border:1px solid var(--line);background:var(--bg-card);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;color:var(--ink)}.srv-btn-lg:hover{background:var(--green-2);border-color:var(--green)}.srv-val-lg{font-size:18px;font-weight:700;min-width:24px;text-align:center}.ing-search-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:200;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:var(--shadow-2);overflow:hidden}.ing-search-item{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;border-bottom:1px solid var(--line-2);transition:background .12s}.ing-search-item:last-child{border-bottom:none}.ing-search-item:hover{background:var(--bg-2)}.ing-search-online{background:var(--bg)}.ing-search-online:hover{background:var(--green-2)}.sel-panel{display:flex;flex-wrap:wrap;gap:6px}.sel-chip{display:inline-flex;align-items:center;gap:5px;background:var(--green-2);color:var(--green-ink);border:1px solid rgba(249,115,74,.28);border-radius:999px;padding:4px 10px 4px 8px;font-size:13px;font-weight:600;line-height:1}.sel-chip-x{background:none;border:none;cursor:pointer;color:var(--green-ink);font-size:15px;line-height:1;padding:0 0 0 2px;opacity:.6;display:flex;align-items:center;font-family:inherit}.sel-chip-x:hover{opacity:1}.sel-chip-expired{background:var(--red-2);color:var(--red);border-color:#a1240e4d}.sel-chip-expired .sel-chip-x{color:var(--red)}.sel-chip-soon{background:var(--terra-2);color:var(--terra);border-color:#a140124d}.sel-chip-soon .sel-chip-x{color:var(--terra)}.chip-label-btn{background:none;border:none;cursor:pointer;color:inherit;font:inherit;font-weight:600;padding:0;display:inline-flex;align-items:center;gap:4px;line-height:1}.chip-expiry-badge{font-size:9px;font-weight:700;padding:1px 5px;border-radius:99px;text-transform:uppercase;letter-spacing:.04em;line-height:1.4}.chip-badge-expired{background:var(--red);color:#fff}.chip-badge-soon{background:var(--terra);color:#fff}.chip-diet-badge{font-size:9px;font-weight:700;padding:1px 5px;border-radius:99px;background:var(--amber);color:#fff;letter-spacing:.02em;cursor:default}.diet-prefs-banner{display:flex;align-items:flex-start;gap:8px;background:var(--amber-2);border:1px solid rgba(140,97,10,.3);border-radius:var(--r-sm);padding:10px 14px;font-size:12px;color:var(--amber);margin:0 20px 8px;line-height:1.5}.diet-prefs-banner strong{font-weight:700;display:block;margin-bottom:2px}.recipe-diet-warning{font-size:10px;font-weight:700;padding:2px 8px;border-radius:999px;background:var(--amber-2);color:var(--amber);border:1px solid rgba(140,97,10,.3);display:inline-flex;align-items:center;gap:3px}.expiry-storage-tip{display:flex;align-items:center;justify-content:space-between;background:var(--bg-2);border-radius:var(--r-sm);padding:8px 12px;margin-bottom:14px;font-size:13px}.expiry-storage-loc{font-weight:700}.expiry-storage-dur{color:var(--ink-3);font-size:12px}.expiry-date-field{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.expiry-date-label{font-size:12px;font-weight:700;color:var(--ink-2);text-transform:uppercase;letter-spacing:.04em;display:flex;align-items:center;gap:6px;font-family:var(--mono)}.expiry-mode-tag{font-size:10px;font-weight:500;color:var(--ink-3);background:var(--bg-3);padding:1px 6px;border-radius:99px;text-transform:none;letter-spacing:0}.expiry-date-input{width:100%;padding:9px 12px;font-size:14px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--bg-card);color:var(--ink);font-family:inherit}.section-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:6px 0;-webkit-user-select:none;user-select:none}.section-header:hover .section-label-text{color:var(--green)}.section-label-text{font-size:11px;font-weight:700;color:var(--ink-3);letter-spacing:.06em;text-transform:uppercase;font-family:var(--mono)}.section-count{font-size:11px;font-weight:700;background:var(--green);color:#fff;border-radius:999px;padding:1px 7px;line-height:1.6}.section-chevron{font-size:12px;color:var(--ink-3)}.diet-group-label{font-size:10px;font-weight:700;color:var(--ink-3);letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px;font-family:var(--mono)}.btn-link{background:none;border:none;cursor:pointer;font-size:12px;color:var(--green);font-family:inherit;padding:0;text-decoration:underline;opacity:.8}.btn-link:hover{opacity:1}.product-card{background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--r-sm);padding:12px;margin-top:10px;font-size:13px}.price-badge{font-size:12px;font-weight:700;color:var(--green);background:var(--green-2);border-radius:999px;padding:2px 8px;margin-left:auto;white-space:nowrap;flex-shrink:0}.price-summary{background:var(--green-2);border:1px solid rgba(249,115,74,.22);border-radius:var(--r);padding:16px 18px}.nutr-row{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin:10px 0}.nc{background:var(--bg-2);border-radius:var(--r-sm);padding:6px 4px;text-align:center}.nc .v{font-size:14px;font-weight:700;color:var(--ink)}.nc .l{font-size:10px;color:var(--ink-3);margin-top:1px}.site-footer{background:var(--bg-2);border-top:1px solid var(--line-2);padding:10px 20px 14px;text-align:center;margin-top:auto;flex-shrink:0}.footer-compact-row{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:6px}.footer-copy-sm{font-size:11px;color:var(--ink-3)}.footer-version-sm{font-size:10px;color:var(--ink-4);font-family:var(--mono)}.footer-links-sm{display:flex;justify-content:center;gap:6px 14px;flex-wrap:wrap}.footer-links-sm a{font-size:11px;color:var(--ink-3);transition:color .15s;text-decoration:none}.footer-links-sm a:hover{color:var(--green)}@media (max-width: 1023px){.site-footer--app{display:none}}@media (min-width: 1024px) and (max-width: 1279px){.site-footer{padding:8px 24px 12px}}@media (min-width: 1280px){.site-footer{padding:8px 40px 12px}}.offline-banner{position:fixed;top:0;left:0;right:0;z-index:9999;background:#92400e;color:#fef3c7;padding:8px 16px;font-size:13px;font-weight:600;text-align:center;box-shadow:0 2px 8px #0003}.install-banner{position:fixed;z-index:9990;width:min(calc(100vw - 32px),420px);background:var(--bg-card, #fff);color:var(--ink);border-radius:14px;border:1px solid var(--line-2);padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;box-shadow:0 4px 24px #00000024;animation:toast-slide-up .25s ease}@media (max-width: 767px){.install-banner{left:50%;bottom:calc(84px + env(safe-area-inset-bottom,0px));transform:translate(-50%)}}@media (min-width: 768px){.install-banner{right:24px;bottom:24px}}@keyframes toast-slide-up{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media (min-width: 768px){@keyframes toast-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}}.install-banner-text{display:flex;flex-direction:column;gap:2px;flex:1;min-width:140px;font-size:13px;line-height:1.5}.install-banner-text strong{font-size:14px}.install-banner-text span{color:var(--ink-3)}.install-banner-actions{display:flex;gap:8px;flex-shrink:0}.install-btn{padding:8px 14px;border-radius:8px;border:none;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit}.install-btn-dismiss{background:var(--bg-2);color:var(--ink-3)}.install-btn-install{background:var(--green);color:#fff}.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:#1a1a1a;color:#f0f0f0;padding:16px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;box-shadow:0 -2px 16px #0000002e;border-top:1px solid rgba(255,255,255,.08)}.cookie-banner-text{font-size:13px;line-height:1.6;flex:1;min-width:200px}.cookie-banner-text a{color:#b5a690;text-decoration:underline}.cookie-banner-actions{display:flex;gap:10px;flex-shrink:0}.cookie-btn{padding:8px 18px;border-radius:6px;border:none;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit}.cookie-btn-decline{background:#ffffff1a;color:#ccc}.cookie-btn-accept{background:var(--green);color:#fff}.legal-page{max-width:720px;margin:0 auto;padding:40px 24px}.legal-page h1{font-family:var(--serif);font-size:28px;font-weight:700;color:var(--ink);margin-bottom:8px}.legal-page .legal-date{font-size:13px;color:var(--ink-3);margin-bottom:32px}.legal-page h2{font-family:var(--serif);font-size:18px;font-weight:700;color:var(--ink);margin:28px 0 12px}.legal-page p{font-size:14px;color:var(--ink-2);line-height:1.8;margin-bottom:12px}.legal-page ul{padding-left:20px;margin-bottom:12px}.legal-page li{font-size:14px;color:var(--ink-2);line-height:1.8;margin-bottom:4px}.legal-page a{color:var(--green)}.legal-nav{display:flex;align-items:center;gap:8px;margin-bottom:32px;padding:12px 0 16px;border-bottom:1px solid var(--line-2);position:sticky;top:0;background:var(--bg);z-index:50;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.legal-nav a{font-size:14px;color:var(--green);font-weight:600}.legal-nav .sep{color:var(--ink-3)}.legal-back{display:inline-flex;align-items:center;gap:5px;font-size:13px;color:var(--green);font-weight:700;background:none;border:none;cursor:pointer;padding:0}.admin-layout{display:flex;min-height:100vh;flex-direction:column}@media (min-width: 768px){.admin-layout{flex-direction:row}}.admin-sidebar{width:100%;background:var(--ink);color:#fff;display:flex;flex-direction:row;flex-wrap:wrap;padding:0 12px 12px;position:relative;z-index:200;flex-shrink:0}@media (min-width: 768px){.admin-sidebar{width:220px;flex-direction:column;flex-wrap:nowrap;padding:0 12px 24px;position:fixed;left:0;top:0;height:100%}}.admin-sidebar-logo{font-family:var(--serif);font-size:15px;font-weight:700;color:#fff;padding:20px 8px 16px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:12px}.admin-sidebar-logo span{display:block;font-size:11px;font-weight:400;color:#ffffff80;margin-top:2px;font-family:var(--sans)}.admin-nav{display:flex;flex-direction:column;gap:2px;flex:1}.admin-nav-btn{display:flex;align-items:center;gap:10px;padding:10px 12px;border:none;border-radius:var(--r-sm);background:none;cursor:pointer;font-size:13px;font-weight:600;color:#ffffffa6;font-family:inherit;width:100%;transition:background .15s,color .15s;text-decoration:none}.admin-nav-btn:hover{background:#ffffff14;color:#fff}.admin-nav-btn.active{background:var(--green);color:#fff}.admin-nav-btn .an-icon{font-size:16px}.admin-nav-divider{height:1px;background:#ffffff1a;margin:8px 0}.admin-content{margin-left:0;flex:1;padding:20px 16px;min-height:100vh;overflow-x:auto}@media (min-width: 768px){.admin-content{margin-left:220px;padding:32px}}.admin-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}.admin-topbar h1{font-family:var(--serif);font-size:24px;font-weight:700;color:var(--ink)}.admin-topbar .topbar-right{display:flex;align-items:center;gap:12px}.admin-badge{font-size:11px;padding:3px 10px;border-radius:999px;font-weight:700;background:var(--green-2);color:var(--green-ink)}.admin-back{font-size:13px;color:var(--green);cursor:pointer;background:none;border:none;font-family:inherit}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:28px}.admin-stat-card{background:var(--bg-card);border:1px solid var(--line-2);border-radius:var(--r);padding:20px;box-shadow:var(--shadow-1)}.admin-stat-card .asc-label{font-size:12px;font-weight:700;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;font-family:var(--mono)}.admin-stat-card .asc-value{font-size:28px;font-weight:700;color:var(--ink);font-family:var(--serif)}.admin-stat-card .asc-sub{font-size:12px;color:var(--ink-3);margin-top:4px}.admin-table-wrap{background:var(--bg-card);border:1px solid var(--line-2);border-radius:var(--r);box-shadow:var(--shadow-1);overflow:hidden}.admin-table{width:100%;border-collapse:collapse}.admin-table th{padding:12px 16px;text-align:left;font-size:11px;font-weight:700;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;background:var(--bg-2);border-bottom:1px solid var(--line-2);font-family:var(--mono)}.admin-table td{padding:12px 16px;font-size:13px;color:var(--ink-2);border-bottom:1px solid var(--line-2)}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--bg)}.admin-table .td-name{font-weight:600;color:var(--ink)}.admin-table .td-badge{display:inline-block;font-size:10px;padding:2px 8px;border-radius:999px;font-weight:700}.admin-table .td-badge.green{background:var(--green-2);color:var(--green-ink)}.admin-table .td-badge.orange{background:var(--terra-2);color:var(--terra)}.admin-table .td-badge.red{background:var(--red-2);color:var(--red)}.admin-table .td-badge.blue{background:var(--blue-light);color:var(--blue)}.admin-search{padding:10px 14px;border:1px solid var(--line);border-radius:var(--r-sm);font-size:13px;font-family:inherit;background:var(--bg);outline:none;width:240px}.admin-search:focus{border-color:var(--green)}.log-viewer{background:#1a1916;border-radius:var(--r);padding:16px;font-family:var(--mono);font-size:12px;line-height:1.8;color:#d4c9b0;max-height:500px;overflow-y:auto}.log-line.error{color:#f5a898}.log-line.warn{color:#f0c880}.log-line.info{color:#8dc49c}.admin-chart-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px;margin-bottom:28px}.admin-chart-card{background:var(--bg-card);border:1px solid var(--line-2);border-radius:var(--r);padding:20px;box-shadow:var(--shadow-1)}.admin-chart-card h3{font-family:var(--serif);font-size:16px;font-weight:700;margin-bottom:16px;color:var(--ink)}.revenue-placeholder{background:var(--bg-card);border:1px solid var(--line-2);border-radius:var(--r);padding:48px;text-align:center;box-shadow:var(--shadow-1)}.revenue-placeholder .rp-icon{font-size:48px;margin-bottom:16px}.revenue-placeholder h3{font-family:var(--serif);font-size:20px;font-weight:700;margin-bottom:8px}.revenue-placeholder p{font-size:14px;color:var(--ink-3);max-width:400px;margin:0 auto;line-height:1.7}.twofa-setup{max-width:480px;margin:0 auto}.twofa-qr{background:var(--bg-card);border:1px solid var(--line-2);border-radius:var(--r);padding:24px;text-align:center;margin-bottom:20px;box-shadow:var(--shadow-1)}.twofa-qr img{max-width:200px;margin:0 auto 16px;display:block}button,.ing-card,.diet-toggle,.tab-btn,.nav-btn,.recipe-card,.modal-opt,.saved-card{-webkit-tap-highlight-color:transparent;touch-action:manipulation}@media (max-width: 480px){.cookie-banner{flex-direction:column;align-items:flex-start}.cookie-banner-actions{width:100%}.cookie-btn{flex:1;text-align:center}.auth-box{padding:28px 20px}.auth-overlay{align-items:flex-start;overflow-y:auto;padding:16px 16px 32px}.tab-btn{font-size:9px;letter-spacing:.02em}.ing-em{font-size:22px}}@media (max-width: 360px){.app-header{padding:10px 12px}.tab-content,.detail-body{padding:14px 12px}.detail-header{padding:12px}.auth-box{padding:20px 14px}.auth-logo{font-size:22px}.ing-grid{grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:6px}.ing-em{font-size:20px}.ing-lbl{font-size:9px}.modal-box{padding:16px}.stor-card{padding:12px}}@media (max-height: 600px) and (orientation: landscape){.auth-overlay{align-items:flex-start;overflow-y:auto;padding:12px}.auth-box{padding:20px 24px}.auth-logo{margin-bottom:4px}.auth-subtitle{margin-bottom:12px;font-size:13px}.auth-btn{padding:10px}.onboarding-step-content{padding:0 16px 16px!important}}@media (min-width: 768px) and (max-width: 1023px){.app-sidebar{display:flex;width:200px}.app-main{max-width:none!important;margin:0 0 0 200px!important;width:calc(100% - 200px)!important}.bottom-nav{display:none!important}.app-header{padding:14px 24px}.tab-content{padding:20px 24px}.auth-box{max-width:480px}.recipe-list-grid{display:grid!important;grid-template-columns:repeat(2,1fr)!important;gap:14px!important}}@media (min-width: 640px){:root{--header-h: 65px}.app-main{max-width:700px}.app-header{padding:16px 28px}.tab-content,.detail-body{padding:24px 28px}.detail-header{padding:16px 28px}.ing-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:10px}.tab-btn{padding:13px 8px;font-size:10px}.auth-box{padding:44px 40px}.recipe-card h3{font-size:19px}}@media (min-width: 900px) and (max-width: 1023px){.app-main{max-width:860px}.app-header{padding:16px 32px}.recipe-list-grid{display:grid!important;grid-template-columns:repeat(2,1fr)!important;gap:14px!important}.ing-grid{grid-template-columns:repeat(auto-fill,minmax(94px,1fr))}.plan-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.modal-overlay{align-items:center!important}}@media (min-width: 1024px){html,body{height:100%}.app-sidebar{display:flex}.app-main{max-width:none!important;margin:0 0 0 var(--sidebar-w)!important;width:calc(100% - var(--sidebar-w))!important;padding-bottom:0!important}.bottom-nav{display:none!important}.app-header{padding:16px 40px}.tab-content,.detail-body{padding:28px 40px}.detail-header{padding:16px 40px}.ing-grid{grid-template-columns:repeat(auto-fill,minmax(96px,1fr))}.recipe-list-grid{display:grid!important;grid-template-columns:repeat(2,1fr)!important;gap:16px!important}.results-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.plan-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.modal-overlay{align-items:center!important}.modal-box{border-radius:22px!important;max-width:540px}[style*="position: fixed"][style*="bottom: 0"]{border-radius:22px!important}.auth-box{max-width:440px;padding:48px 44px}.profile-page-inner{max-width:720px;margin:0 auto}}@media (min-width: 1400px){:root{--header-h: 69px;--sidebar-w: 280px}.recipe-list-grid{grid-template-columns:repeat(3,1fr)!important}.results-grid{grid-template-columns:repeat(3,1fr)}.app-header{padding:18px 52px}.tab-content{padding:32px 52px}}.nf-label{border:2px solid var(--ink);border-radius:4px;padding:7px 10px 6px;background:var(--bg-card);color:var(--ink);font-size:13px;line-height:1.3;width:100%;box-sizing:border-box}.nf-title{font-size:26px;font-weight:900;line-height:1.05;letter-spacing:-.3px;font-family:var(--serif)}.nf-serving{font-size:12px;color:var(--ink-2);margin-top:1px;margin-bottom:3px}.nf-bar{margin:3px 0}.nf-bar-thick{border-top:9px solid var(--ink)}.nf-bar-med{border-top:4px solid var(--ink)}.nf-bar-thin{border-top:1px solid var(--ink-3)}.nf-amount-hd{font-size:12px;margin:2px 0 0}.nf-calories-row{display:flex;align-items:baseline;justify-content:space-between}.nf-calories-lbl{font-size:15px;font-weight:700}.nf-calories-num{font-size:36px;font-weight:900;line-height:1.05;font-family:var(--serif)}.nf-dv-hd{text-align:right;font-size:11px;font-weight:700;border-top:1px solid var(--ink-3);padding-top:2px;margin-bottom:1px}.nf-row{display:flex;align-items:baseline;justify-content:space-between;border-top:1px solid var(--ink-3);padding:2px 0;font-size:13px;gap:4px}.nf-row.nf-bold{font-weight:700}.nf-row.nf-sub{padding-left:14px;font-weight:400}.nf-row.nf-sub2{padding-left:28px;font-weight:400;font-size:12px}.nf-row.nf-thin{border-top:none;padding-top:0}.nf-row-label{flex:1;min-width:0}.nf-row-val,.nf-row.nf-bold .nf-row-val{font-weight:400}.nf-row-pct{min-width:36px;text-align:right;font-weight:700;font-size:12px;flex-shrink:0}.nf-micro-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 6px}.nf-micro-row{display:flex;justify-content:space-between;align-items:baseline;font-size:11px;padding:2px 0;border-top:1px solid var(--ink-3);gap:2px}.nf-micro-label{flex:1;min-width:0}.nf-micro-pct{font-weight:700;min-width:28px;text-align:right;flex-shrink:0}.nf-footnote{font-size:9px;color:var(--ink-3);line-height:1.4;margin-top:4px}.nf-ctrl{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.nf-ctrl-label{font-size:12px;font-weight:600;color:var(--ink-2)}.nf-ctrl-btns{display:flex;align-items:center;gap:8px}.nf-ctrl-btn{width:28px;height:28px;border-radius:50%;border:1px solid var(--line);background:var(--bg-card);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;color:var(--ink);transition:background .15s}.nf-ctrl-btn:hover{background:var(--green-2);border-color:var(--green)}.nf-ctrl-val{font-size:14px;font-weight:700;min-width:52px;text-align:center;color:var(--ink);font-family:var(--mono)}@media (min-width: 1800px){.app-layout{max-width:2400px;margin-left:auto;margin-right:auto}.recipe-list-grid{grid-template-columns:repeat(4,1fr)!important}.results-grid{grid-template-columns:repeat(4,1fr)}}:root{--sb-tint: #F9734A;--sb-tint-frosted: rgba(249,115,74,.72)}[data-theme=warm],[data-theme=light]{--sb-tint: #F9734A;--sb-tint-frosted: rgba(249,115,74,.72)}[data-theme=calm]{--sb-tint: #E85D3F;--sb-tint-frosted: rgba(232,93,63,.68)}[data-theme=dark]{--sb-tint: #1C1612;--sb-tint-frosted: rgba(28,22,18,.8)}[data-theme=blue]{--sb-tint: #2D8CFF;--sb-tint-frosted: rgba(45,140,255,.72)}[data-theme=crayon]{--sb-tint: #EF5350;--sb-tint-frosted: rgba(239,83,80,.72)}[data-theme=matcha]{--sb-tint: #6FA86F;--sb-tint-frosted: rgba(111,168,111,.72)}[data-theme=strawberry]{--sb-tint: #F0657D;--sb-tint-frosted: rgba(240,101,125,.72)}[data-theme=sesame]{--sb-tint: #C87941;--sb-tint-frosted: rgba(200,121,65,.72)}[data-mode=dark]{--sb-tint: #1C1612;--sb-tint-frosted: rgba(28,22,18,.8)}.mobile-status-blur{display:none;position:fixed;top:0;left:0;right:0;height:var(--sb-h);z-index:9999;pointer-events:none;background:var(--sb-tint);-webkit-backdrop-filter:none;backdrop-filter:none;transition:background .18s ease,backdrop-filter .18s ease,-webkit-backdrop-filter .18s ease}.mobile-status-blur.scrolled{background:var(--sb-tint-frosted);-webkit-backdrop-filter:blur(18px) saturate(140%);backdrop-filter:blur(18px) saturate(140%)}@media (max-width: 767px){:root{--sb-h: max(env(safe-area-inset-top, 0px), 24px)}.mobile-status-blur{display:block}.app-main{padding-top:var(--sb-h)}header.app-header{top:var(--sb-h)}.tab-bar{top:calc(var(--header-h) + var(--sb-h))}.detail-header{top:var(--sb-h)}}.header-brand{display:inline-flex;align-items:center}.header-logo-sep{color:var(--ink-4);font-size:15px;margin:0 2px 0 4px;line-height:1;-webkit-user-select:none;user-select:none}.header-page-title{font-weight:500;color:var(--ink-3);font-size:15px;line-height:1}@media (min-width: 768px){.header-brand{display:none}.header-page-title{font-size:17px;font-weight:700;color:var(--ink)}}@media (max-width: 1024px){input:not([type=hidden]):not([type=range]):not([type=checkbox]):not([type=radio]),textarea,select{font-size:16px!important}}@media (max-width: 639px){.fridge-greeting{display:none!important}}.recipe-action-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 0 4px}.recipe-action-grid>button,.recipe-action-grid>div{width:100%;min-width:0}.recipe-action-grid>div>button{width:100%}@media (min-width: 1024px){.recipe-action-grid{grid-template-columns:repeat(4,1fr)}}.recipe-filter-mobile-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:0 18px 8px}.recipe-filter-pill{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border-radius:999px;font-size:13px;font-weight:700;border:1.5px solid var(--line);cursor:pointer;background:var(--bg-card);color:var(--ink-2);flex-shrink:0;transition:background .15s,border-color .15s}.recipe-filter-pill.has-filters{border-color:var(--green);background:var(--green-2);color:var(--green-ink)}.recipe-active-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;background:var(--green-2);color:var(--green-ink);border:1px solid var(--green);cursor:pointer;flex-shrink:0}@media (max-width: 639px){.recipe-filter-chips{display:none!important}}[data-theme=blue]{--bg: #F2F8FF;--bg-card: #FFFFFF;--bg-2: #DDEEFF;--bg-3: #C4DEFF;--bg2: #DDEEFF;--bg3: #C4DEFF;--ink: #172033;--ink-2: #2A3A55;--ink-3: #718096;--ink-4: #A0AABB;--text: #172033;--text2: #2A3A55;--text3: #718096;--text4: #A0AABB;--line: rgba(23,32,51,.16);--line-2: rgba(23,32,51,.09);--border: rgba(23,32,51,.16);--border2: rgba(23,32,51,.09);--green: #2D8CFF;--green-2: #DDEEFF;--green-ink: #1155BB;--accent: #2D8CFF;--accent-light: #DDEEFF;--brand: #2D8CFF;--brand-soft: #DDEEFF;--brand-ink: #1155BB;--terra: #EF4444;--terra-2: #FEE2E2;--accent2: #EF4444;--accent2-light: #FEE2E2;--success: #55B978;--success-2: #DCFCE7;--success-ink: #166534;--plum: #7C3AED;--plum-2: #EDE9FE;--red: #EF4444;--red-2: #FEE2E2;--red-light: #FEE2E2;--amber: #F59E0B;--amber-2: #FEF3C7;--shadow-1: 0 1px 3px rgba(23,32,51,.06), 0 4px 12px rgba(23,32,51,.06);--shadow-2: 0 2px 8px rgba(23,32,51,.1), 0 14px 32px rgba(23,32,51,.12);--shadow: 0 1px 3px rgba(23,32,51,.06), 0 4px 12px rgba(23,32,51,.06);--shadow-md: 0 2px 8px rgba(23,32,51,.1), 0 14px 32px rgba(23,32,51,.12)}[data-theme=crayon]{--bg: #FFF8E8;--bg-card: #FFFFFF;--bg-2: #FFE8D0;--bg-3: #FFD4B0;--bg2: #FFE8D0;--bg3: #FFD4B0;--ink: #2B211C;--ink-2: #4A332A;--ink-3: #8B7469;--ink-4: #BBA898;--text: #2B211C;--text2: #4A332A;--text3: #8B7469;--text4: #BBA898;--line: rgba(43,33,28,.16);--line-2: rgba(43,33,28,.09);--border: rgba(43,33,28,.16);--border2: rgba(43,33,28,.09);--green: #EF5350;--green-2: #FFE1DE;--green-ink: #C62828;--accent: #EF5350;--accent-light: #FFE1DE;--brand: #EF5350;--brand-soft: #FFE1DE;--brand-ink: #C62828;--terra: #F4B400;--terra-2: #FFF9C4;--accent2: #F4B400;--accent2-light: #FFF9C4;--success: #6DBE7E;--success-2: #DFF2E6;--success-ink: #2A7A48;--plum: #4FA3F7;--plum-2: #DBEAFE;--red: #C0392B;--red-2: #FDECEA;--red-light: #FDECEA;--amber: #D4850A;--amber-2: #FFF3CD;--shadow-1: 0 1px 3px rgba(43,33,28,.07), 0 4px 12px rgba(43,33,28,.07);--shadow-2: 0 2px 8px rgba(43,33,28,.11), 0 14px 32px rgba(43,33,28,.13);--shadow: 0 1px 3px rgba(43,33,28,.07), 0 4px 12px rgba(43,33,28,.07);--shadow-md: 0 2px 8px rgba(43,33,28,.11), 0 14px 32px rgba(43,33,28,.13)}[data-theme=matcha]{--bg: #F6F8EF;--bg-card: #FFFFFF;--bg-2: #E2F0DF;--bg-3: #CCDEC8;--bg2: #E2F0DF;--bg3: #CCDEC8;--ink: #1F241C;--ink-2: #354030;--ink-3: #71806A;--ink-4: #A8B8A0;--text: #1F241C;--text2: #354030;--text3: #71806A;--text4: #A8B8A0;--line: rgba(31,36,28,.15);--line-2: rgba(31,36,28,.08);--border: rgba(31,36,28,.15);--border2: rgba(31,36,28,.08);--green: #6FA86F;--green-2: #E2F0DF;--green-ink: #2D5E2D;--accent: #6FA86F;--accent-light: #E2F0DF;--brand: #6FA86F;--brand-soft: #E2F0DF;--brand-ink: #2D5E2D;--terra: #7A5A36;--terra-2: #F0DEC0;--accent2: #7A5A36;--accent2-light: #F0DEC0;--success: #4F9F64;--success-2: #DCFCE7;--success-ink: #166534;--plum: #5A1E4C;--plum-2: #ECD2E4;--red: #C0392B;--red-2: #FDECEA;--red-light: #FDECEA;--amber: #D4850A;--amber-2: #FFF3CD;--shadow-1: 0 1px 3px rgba(31,36,28,.06), 0 4px 12px rgba(31,36,28,.06);--shadow-2: 0 2px 8px rgba(31,36,28,.1), 0 14px 32px rgba(31,36,28,.12);--shadow: 0 1px 3px rgba(31,36,28,.06), 0 4px 12px rgba(31,36,28,.06);--shadow-md: 0 2px 8px rgba(31,36,28,.1), 0 14px 32px rgba(31,36,28,.12)}[data-theme=strawberry]{--bg: #FFF5F7;--bg-card: #FFFFFF;--bg-2: #FFE1E8;--bg-3: #FFC8D4;--bg2: #FFE1E8;--bg3: #FFC8D4;--ink: #24191B;--ink-2: #442830;--ink-3: #8A6F74;--ink-4: #C0A0A8;--text: #24191B;--text2: #442830;--text3: #8A6F74;--text4: #C0A0A8;--line: rgba(36,25,27,.15);--line-2: rgba(36,25,27,.08);--border: rgba(36,25,27,.15);--border2: rgba(36,25,27,.08);--green: #F0657D;--green-2: #FFE1E8;--green-ink: #9B1D30;--accent: #F0657D;--accent-light: #FFE1E8;--brand: #F0657D;--brand-soft: #FFE1E8;--brand-ink: #9B1D30;--terra: #8A4B3A;--terra-2: #F5D0C0;--accent2: #8A4B3A;--accent2-light: #F5D0C0;--success: #69B77A;--success-2: #DCFCE7;--success-ink: #166534;--plum: #9333EA;--plum-2: #F3E8FF;--red: #C0392B;--red-2: #FDECEA;--red-light: #FDECEA;--amber: #D4850A;--amber-2: #FFF3CD;--shadow-1: 0 1px 3px rgba(36,25,27,.06), 0 4px 12px rgba(36,25,27,.06);--shadow-2: 0 2px 8px rgba(36,25,27,.1), 0 14px 32px rgba(36,25,27,.12);--shadow: 0 1px 3px rgba(36,25,27,.06), 0 4px 12px rgba(36,25,27,.06);--shadow-md: 0 2px 8px rgba(36,25,27,.1), 0 14px 32px rgba(36,25,27,.12)}[data-theme=sesame]{--bg: #F8F1E7;--bg-card: #FFFFFF;--bg-2: #F3DFCA;--bg-3: #E7C9A8;--bg2: #F3DFCA;--bg3: #E7C9A8;--ink: #211A14;--ink-2: #3D2E20;--ink-3: #7D7167;--ink-4: #B8A898;--text: #211A14;--text2: #3D2E20;--text3: #7D7167;--text4: #B8A898;--line: rgba(33,26,20,.16);--line-2: rgba(33,26,20,.09);--border: rgba(33,26,20,.16);--border2: rgba(33,26,20,.09);--green: #C87941;--green-2: #F3DFCA;--green-ink: #7A4820;--accent: #C87941;--accent-light: #F3DFCA;--brand: #C87941;--brand-soft: #F3DFCA;--brand-ink: #7A4820;--terra: #5E3B22;--terra-2: #E8D0B0;--accent2: #5E3B22;--accent2-light: #E8D0B0;--success: #6A9F72;--success-2: #DCFCE7;--success-ink: #166534;--plum: #5A1E4C;--plum-2: #ECD2E4;--red: #C0392B;--red-2: #FDECEA;--red-light: #FDECEA;--amber: #D4850A;--amber-2: #FFF3CD;--shadow-1: 0 1px 3px rgba(33,26,20,.06), 0 4px 12px rgba(33,26,20,.06);--shadow-2: 0 2px 8px rgba(33,26,20,.1), 0 14px 32px rgba(33,26,20,.12);--shadow: 0 1px 3px rgba(33,26,20,.06), 0 4px 12px rgba(33,26,20,.06);--shadow-md: 0 2px 8px rgba(33,26,20,.1), 0 14px 32px rgba(33,26,20,.12)}[data-mode=dark]{--bg: #1C1612;--bg-card: #262018;--bg-2: #302820;--bg-3: #3E3226;--bg2: #302820;--bg3: #3E3226;--ink: #F0EBE0;--ink-2: #C8BCA8;--ink-3: #8A7A6C;--ink-4: #5A4E42;--text: #F0EBE0;--text2: #C8BCA8;--text3: #8A7A6C;--text4: #5A4E42;--line: rgba(240,235,224,.14);--line-2: rgba(240,235,224,.08);--border: rgba(240,235,224,.14);--border2: rgba(240,235,224,.08);--green-2: rgba(255,255,255,.1);--brand-soft: rgba(255,255,255,.1);--terra-2: rgba(255,255,255,.08);--accent2-light: rgba(255,255,255,.08);--success: #5AAA6C;--success-2: #1A3020;--success-ink: #A0D4A8;--plum: #B06898;--plum-2: #2C1428;--red: #D44A30;--red-2: #3A1410;--red-light: #3A1410;--amber: #D4A030;--amber-2: #3A2A08;--shadow-1: 0 1px 2px rgba(0,0,0,.32), 0 2px 8px rgba(0,0,0,.32);--shadow-2: 0 2px 6px rgba(0,0,0,.42), 0 12px 28px rgba(0,0,0,.42);--shadow: 0 1px 2px rgba(0,0,0,.32), 0 2px 8px rgba(0,0,0,.32);--shadow-md: 0 2px 6px rgba(0,0,0,.42), 0 12px 28px rgba(0,0,0,.42)}.fridge-ingredient-grid{display:grid;gap:10px;align-items:stretch;width:100%;max-width:100%;box-sizing:border-box;grid-template-columns:repeat(2,minmax(0,1fr))}@media (min-width: 600px) and (max-width: 899px){.fridge-ingredient-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width: 900px){.fridge-ingredient-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}.fridge-ingredient-card{display:flex;flex-direction:column;box-sizing:border-box;width:100%}.fridge-ingredient-img-wrap{width:100%;height:88px;overflow:hidden;border-radius:10px;flex-shrink:0;margin-bottom:8px;display:flex;align-items:center;justify-content:center}.fridge-ingredient-info{display:grid;gap:5px;margin-top:2px}.fridge-ingredient-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:4px}.fridge-ingredient-name{font-size:12px;font-weight:700;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink)}.fridge-ingredient-quantity{font-size:10px;font-weight:700;font-family:var(--mono);color:var(--ink-2);text-align:right;white-space:nowrap}.fridge-storage-badge{display:inline-flex;align-items:center;gap:2px;font-size:9px;font-weight:700;padding:2px 6px;border-radius:999px;background:var(--green-2);color:var(--green-ink);border:1px solid rgba(249,115,74,.2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.fridge-expiry-badge{font-size:9px;font-weight:700;font-family:var(--mono);text-align:right;white-space:nowrap}.fridge-content-wrap{width:100%;max-width:100%;box-sizing:border-box;overflow:hidden;padding-bottom:32px}.use-soon-card{background:#fffbf0;border:1.5px solid rgba(212,133,10,.45);border-radius:14px;padding:12px;box-shadow:0 2px 8px #d4850a1a;cursor:pointer;text-align:left;transition:border-color .15s;flex:0 0 136px}.use-soon-card:hover{border-color:#d4850ab3}.use-soon-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:999px;font-size:10px;font-weight:700;background:#d4850a26;color:#a06300;border:1px solid rgba(212,133,10,.3)}.expired-card{background:#fff5f5;border-color:#c0392b66}.expired-badge{background:#c0392b1f;color:var(--red);border-color:#c0392b4d}.saved-recipes-grid{display:grid;gap:14px}@media (max-width: 767px){.saved-recipes-grid{grid-template-columns:1fr}}@media (min-width: 768px) and (max-width: 1099px){.saved-recipes-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1100px){.saved-recipes-grid{grid-template-columns:repeat(auto-fill,minmax(280px,360px));justify-content:start}}.saved-recipes-content{width:100%;max-width:1180px;margin:0 auto;padding:0 18px;box-sizing:border-box}.page-section,.content-section,.section-card{position:relative;width:100%;max-width:100%;height:auto;min-height:auto;box-sizing:border-box}.section-grid,.card-grid{width:100%;max-width:100%;box-sizing:border-box}.page-content,.tab-content{overflow-x:hidden;width:100%;max-width:100%;box-sizing:border-box}.page-footer-gap{height:32px;flex-shrink:0}.add-list-grid,.ingredient-picker-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;align-items:stretch}.add-list-card,.ingredient-picker-card{min-height:52px;display:flex;flex-direction:column;box-sizing:border-box}.grocery-search-sticky{position:sticky;top:0;z-index:2;background:var(--bg);padding-bottom:6px;margin-bottom:8px}.recipes-sticky-toolbar{position:sticky;top:var(--header-h);z-index:80;background:color-mix(in srgb,var(--bg) 95%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line-2);padding:10px 18px 8px}@media (max-width: 767px){.recipes-sticky-toolbar{top:calc(var(--header-h) + var(--sb-h))}}
