:root{--bg: #F6F2E8;--bg-sunk: #EFE9DA;--surface: #FFFFFF;--surface-2: #FBF8F1;--border: #E7E0D1;--border-strong: #D7CDB9;--ink: #15241C;--ink-2: #46554C;--ink-3: #7C877E;--brand: #13503A;--brand-600: #1A7A57;--brand-500: #1E8C64;--brand-tint: #E4F1E9;--accent: #F4B740;--accent-strong: #E9A516;--accent-ink: #6A4D10;--accent-tint: #FCF1D5;--danger: #C23A2B;--danger-tint: #FBE7E3;--danger-ink: #8C2017;--warn: #B07417;--warn-tint: #FAEFD2;--warn-ink: #7A4F0E;--ok: #1A7A57;--ok-tint: #E1F1E8;--neutral: #5C6B63;--neutral-tint: #ECEFEC;--shadow-sm: 0 1px 2px rgba(18,40,30,.06);--shadow-md: 0 6px 20px rgba(18,40,30,.08);--shadow-lg: 0 16px 40px rgba(18,40,30,.14);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-top: env(safe-area-inset-top, 0px)}[data-theme=dark]{--bg: #0D1411;--bg-sunk: #080D0B;--surface: #15201B;--surface-2: #1A2620;--border: #27332D;--border-strong: #36453E;--ink: #ECF3EE;--ink-2: #A8B7AE;--ink-3: #74837A;--brand: #2FA078;--brand-600: #36B083;--brand-500: #41C091;--brand-tint: #14271F;--accent: #F4C24D;--accent-strong: #F4B740;--accent-ink: #F4C24D;--accent-tint: #2C2411;--danger: #E6705F;--danger-tint: #2D1915;--danger-ink: #F0A89D;--warn: #E0A53C;--warn-tint: #2B2310;--warn-ink: #E9C079;--ok: #41C091;--ok-tint: #15271F;--neutral: #8C9A91;--neutral-tint: #1D2722;--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 6px 20px rgba(0,0,0,.4);--shadow-lg: 0 16px 40px rgba(0,0,0,.5)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0}body{font-family:Hanken Grotesk,system-ui,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}@keyframes hl-spin{to{transform:rotate(360deg)}}@keyframes hl-shimmer{0%{background-position:-460px 0}to{background-position:460px 0}}@keyframes hl-rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.shell{min-height:100vh;background:var(--bg);color:var(--ink);transition:background .25s,color .25s}.appbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:calc(var(--safe-top) + 10px) 18px 12px;background:color-mix(in srgb,var(--bg) 86%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.brand-row{display:flex;align-items:center;gap:11px}.logo{width:36px;height:36px;border-radius:11px;background:var(--brand);display:grid;place-items:center;box-shadow:var(--shadow-sm);flex:0 0 auto}.brand-name{font-size:18px;font-weight:800;letter-spacing:-.02em;line-height:1.15}.brand-tag{font-size:12px;color:var(--ink-3);font-weight:500}.icon-btn{width:40px;height:40px;border-radius:12px;border:1px solid var(--border);background:var(--surface);color:var(--ink-2);display:grid;place-items:center;cursor:pointer;flex:0 0 auto}.content{max-width:720px;margin:0 auto;padding:18px 16px calc(96px + var(--safe-bottom))}.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:60;display:flex;align-items:flex-end;padding:6px 8px calc(8px + var(--safe-bottom));background:color-mix(in srgb,var(--surface) 90%,transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-top:1px solid var(--border)}.tab{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;padding:8px 2px 4px;border:none;background:none;cursor:pointer;font-family:inherit;font-size:10.5px;font-weight:600;color:var(--ink-3);text-decoration:none}.tab-pill{width:46px;height:30px;border-radius:999px;display:grid;place-items:center;background:transparent;transition:background .2s}.tab.active{color:var(--brand-600);font-weight:700}.tab.active .tab-pill{background:var(--brand-tint)}.sidebar{display:none}.layout{display:block}@media(min-width:900px){.appbar,.tabbar{display:none}.layout{max-width:1200px;margin:0 auto;padding:26px 22px}.frame{background:var(--surface);border:1px solid var(--border);border-radius:22px;box-shadow:var(--shadow-lg);overflow:hidden;display:flex;min-height:720px}.sidebar{display:flex;width:250px;flex:0 0 250px;border-right:1px solid var(--border);background:var(--surface-2);flex-direction:column;padding:20px 16px}.content{max-width:none;margin:0;flex:1;min-width:0;padding:26px 32px 36px}}.side-brand{display:flex;align-items:center;gap:11px;padding:6px 8px 18px}.side-nav{display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 13px;border-radius:12px;border:none;cursor:pointer;font-family:inherit;font-size:14px;font-weight:600;width:100%;text-align:left;background:transparent;color:var(--ink-2);text-decoration:none}.nav-item.active{background:var(--brand-tint);color:var(--brand-600);font-weight:700}.side-foot{margin-top:auto;padding:14px 12px;background:var(--brand-tint);border-radius:14px}.side-foot b{font-size:12.5px;font-weight:800;color:var(--brand-600);display:block}.side-foot span{font-size:11.5px;color:var(--ink-2);line-height:1.45;margin-top:3px;display:block}.page{display:flex;flex-direction:column;gap:14px;animation:hl-rise .25s ease both}.page-top{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}.overline{font-size:11px;font-weight:800;letter-spacing:.09em;color:var(--brand-600);text-transform:uppercase}.title{margin:4px 0 0;font-size:21px;font-weight:800;letter-spacing:-.02em}.intro{margin:0;font-size:13.5px;line-height:1.5;color:var(--ink-2)}@media(min-width:900px){.title{font-size:27px;letter-spacing:-.025em;margin:5px 0 0}.intro{font-size:15px;line-height:1.55;max-width:680px}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:14px;border-radius:14px;border:none;font-family:inherit;font-size:15px;font-weight:700;cursor:pointer;transition:transform .08s ease}.btn:active{transform:scale(.98)}.btn-block{width:100%}.btn--primary{background:var(--brand-600);color:#fff;box-shadow:var(--shadow-md)}.btn--loading{background:var(--brand-600);color:#fff;opacity:.9;cursor:default}.btn--secondary{background:var(--surface);color:var(--ink-2);border:1.5px solid var(--border);font-size:14.5px;border-radius:13px}.btn--ghost{background:transparent;color:var(--ok);border:1.5px solid color-mix(in srgb,var(--ok) 45%,transparent);border-radius:12px;font-size:13.5px;min-height:44px;flex:1}.btn--danger{background:var(--danger-tint);color:var(--danger-ink);border:1px solid color-mix(in srgb,var(--danger) 30%,transparent);border-radius:12px;font-size:13.5px;min-height:44px;flex:1}.btn--ico{padding:9px 14px;border-radius:11px;border:1px solid var(--border);background:var(--surface);color:var(--ink-2);font-size:12.5px;font-weight:700;gap:6px}.btn[disabled]{cursor:default}.btn .emoji{font-size:17px}.spin{animation:hl-spin .8s linear infinite}.search{position:relative;display:flex;align-items:center}.search svg{position:absolute;left:14px}.field{width:100%;padding:13px 14px 13px 42px;border-radius:13px;border:1.5px solid var(--border);background:var(--surface);color:var(--ink);font-family:inherit;font-size:14.5px;outline:none}.field:focus{border-color:var(--brand-500);box-shadow:0 0 0 3px var(--brand-tint)}.chip{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;border-radius:999px;border:1.5px solid var(--border);background:var(--surface);color:var(--ink-2);font-family:inherit;font-size:13.5px;font-weight:700;cursor:pointer}.chip.on{border-color:var(--brand-500);background:var(--brand-tint);color:var(--brand-600)}.pill{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:999px;background:var(--surface-2);color:var(--ink-2);border:1px solid var(--border);font-size:13px;font-weight:600}.pill--accent{background:var(--accent-tint);color:var(--accent-ink);border-color:color-mix(in srgb,var(--accent) 45%,transparent);font-weight:700}.pill--check{color:var(--ink-3)}.pills{display:flex;flex-wrap:wrap;gap:8px}.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:14px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:9px}.card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.card-title{font-size:15.5px;font-weight:700;letter-spacing:-.01em}.card-meta{font-size:12.5px;color:var(--ink-3);font-weight:500}.rec{display:flex;gap:7px;align-items:flex-start;font-size:13px;line-height:1.45;color:var(--ink-2);background:var(--surface-2);border-radius:10px;padding:9px 11px}.rec svg{flex:0 0 auto;margin-top:1px}@media(min-width:900px){.card{padding:16px}.card-title{font-size:16px}}.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px 3px 8px;border-radius:999px;font-size:12px;font-weight:700;white-space:nowrap}.badge .dot{width:7px;height:7px;border-radius:999px;flex:0 0 auto}.badge--expired{background:var(--danger-tint);color:var(--danger-ink)}.badge--expired .dot{background:var(--danger)}.badge--expiring_soon{background:var(--warn-tint);color:var(--warn-ink)}.badge--expiring_soon .dot{background:var(--warn)}.badge--ok{background:var(--ok-tint);color:var(--ok)}.badge--ok .dot{background:var(--ok)}.badge--unknown{background:var(--neutral-tint);color:var(--ink-2)}.badge--unknown .dot{background:var(--neutral)}.conf-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:999px;background:var(--brand-tint);color:var(--brand-600);font-size:12.5px;font-weight:800}.stats{display:flex;gap:11px}.stat{flex:1;border-radius:16px;padding:15px}.stat-lbl{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700}.stat-num{font-size:34px;font-weight:800;line-height:1.1;margin-top:4px}.stat-sub{font-size:12px;color:var(--ink-3);font-weight:500}.stat--ok{background:var(--ok-tint);border:1px solid color-mix(in srgb,var(--ok) 25%,transparent)}.stat--ok .stat-lbl,.stat--ok .stat-num{color:var(--ok)}.stat--bad{background:var(--danger-tint);border:1px solid color-mix(in srgb,var(--danger) 25%,transparent)}.stat--bad .stat-lbl,.stat--bad .stat-num{color:var(--danger)}.stat--rate{display:none;background:var(--surface);border:1px solid var(--border)}.stat--rate .stat-lbl{color:var(--ink-2)}.stat--rate .stat-num{color:var(--brand-600)}@media(min-width:900px){.stats{display:grid;grid-template-columns:repeat(3,1fr);max-width:760px}.stat{border-radius:18px;padding:18px}.stat-num{font-size:40px;line-height:1.05;margin-top:6px}.stat--rate{display:block}}.empty{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding:36px 20px;background:var(--surface-2);border:1px dashed var(--border-strong);border-radius:16px}.empty-ico{width:52px;height:52px;border-radius:16px;background:var(--bg-sunk);display:grid;place-items:center;color:var(--ink-3)}.empty-title{font-size:15px;font-weight:700}.empty-text{font-size:13px;color:var(--ink-3);line-height:1.5;max-width:240px}@media(min-width:900px){.empty{padding:54px 20px;border-radius:18px;max-width:760px}.empty-ico{width:60px;height:60px;border-radius:18px}.empty-title{font-size:17px}.empty-text{font-size:14px;max-width:340px}}.banner{display:flex;gap:11px;align-items:flex-start;padding:13px 14px;background:var(--danger-tint);border:1px solid color-mix(in srgb,var(--danger) 35%,transparent);border-radius:14px}.banner svg{flex:0 0 auto;margin-top:1px}.banner-title{font-size:14px;font-weight:700;color:var(--danger-ink)}.banner-sub{font-size:12.5px;color:var(--danger-ink);opacity:.85;line-height:1.45;margin-top:2px}@media(min-width:900px){.banner{padding:16px 18px;border-radius:16px;max-width:680px}.banner-title{font-size:15px}.banner-sub{font-size:13.5px}}.loading-row{display:flex;align-items:center;gap:10px;font-size:14.5px;font-weight:700;color:var(--brand-600)}.skel{border:1px solid var(--border);background:var(--surface);border-radius:16px;padding:14px;display:flex;flex-direction:column;gap:11px}.shimmer{background:linear-gradient(90deg,var(--bg-sunk) 0,var(--surface-2) 45%,var(--bg-sunk) 80%);background-size:600px 100%;animation:hl-shimmer 1.2s infinite linear}.sk-line{height:14px;border-radius:7px}.sk-pill{height:18px;width:60px;border-radius:999px;background:var(--bg-sunk)}.sk-block{height:36px;width:100%;border-radius:10px}.idle-hero{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:14px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px}.photo-slot{width:100%;height:150px;border-radius:14px;border:1.5px dashed var(--border-strong);background:var(--surface-2);display:grid;place-items:center;color:var(--ink-3);cursor:pointer;overflow:hidden}.photo-slot img{width:100%;height:100%;object-fit:cover}.photo-slot-label{display:flex;flex-direction:column;align-items:center;gap:8px;font-size:13px;font-weight:600}.hero-copy{display:none}.tray-hint{margin:0;font-size:12.5px;line-height:1.5;color:var(--ink-3)}.photo-ready{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:700;color:var(--ok)}@media(min-width:900px){.idle-hero{background:var(--surface-2);border-radius:20px;padding:24px;max-width:760px;display:grid;grid-template-columns:1.1fr 1fr;gap:22px;align-items:center}.photo-slot{height:220px;border-radius:16px}.hero-copy{display:flex;flex-direction:column;gap:14px}.hero-copy h3{margin:0;font-size:19px;font-weight:800;letter-spacing:-.01em}.hero-copy p{margin:0;font-size:14px;line-height:1.55;color:var(--ink-2)}.hero-copy .btn{align-self:flex-start;width:auto;padding:14px 20px}}.recipe{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:16px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px}.recipe-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.recipe-title{font-size:17px;font-weight:800;letter-spacing:-.01em}.time-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;background:var(--accent-tint);color:var(--accent-ink);font-size:12px;font-weight:800;white-space:nowrap}.reason{display:flex;gap:7px;align-items:flex-start;font-size:13px;line-height:1.45;color:var(--brand-600);background:var(--brand-tint);border-radius:10px;padding:9px 11px;font-weight:600}.steps{display:flex;flex-direction:column;gap:9px}.step{display:flex;gap:11px;align-items:flex-start}.step-num{flex:0 0 auto;width:24px;height:24px;border-radius:999px;background:var(--brand);color:#fff;display:grid;place-items:center;font-size:12.5px;font-weight:800}.step-text{font-size:13.5px;line-height:1.5;color:var(--ink-2);padding-top:2px}@media(min-width:900px){.recipe{padding:20px;border-radius:18px}.recipe-title{font-size:18px}.step-text{font-size:14px}}.section-label{font-size:13.5px;font-weight:800}.section-label.muted{color:var(--ink-2)}.result-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.result-note{font-size:12.5px;font-weight:700;color:var(--ink-2)}.col{display:flex;flex-direction:column;gap:14px}.grid-cards{display:flex;flex-direction:column;gap:10px}.find-layout{display:flex;flex-direction:column;gap:14px}@media(min-width:900px){.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:16px}.grid-recipes{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:18px;align-items:start}.grid-shop{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;align-items:start}.find-layout{display:grid;grid-template-columns:minmax(0,420px) 1fr;gap:24px;align-items:start}}@media(min-width:900px){.shop-block{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:18px;box-shadow:var(--shadow-sm)}.shop-block--accent{border-color:color-mix(in srgb,var(--accent) 35%,var(--border))}}.btn-row{display:flex;gap:10px}.scan-actions{display:flex;gap:9px}
