:root{--bg:#f0f5f1;--bg-elev:#f7faf8;--bg-deep:#e2ece5;--ink:#0e1a10;--ink-2:#2e4232;--ink-3:#587060;--ink-4:#8fab97;--rule:#0e1a101a;--rule-soft:#0e1a100f;--accent:oklch(52% .17 148);--accent-ink:oklch(36% .14 148);--accent-soft:oklch(93% .05 148);--accent-fg:#fff;--serif:"Fraunces", Georgia, serif;--sans:"DM Sans", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--r-sm:6px;--r-md:10px;--r-lg:14px;--r-xl:22px;--shadow-sm:0 1px 2px #1f1b160a, 0 1px 1px #1f1b1608;--shadow-md:0 2px 6px #1f1b160f, 0 8px 24px #1f1b160f;--shadow-lg:0 4px 12px #1f1b1614, 0 24px 64px #1f1b161a}.dark{--bg:#0d1610;--bg-elev:#141f17;--bg-deep:#0a100c;--ink:#e8f2ea;--ink-2:#b8ccbc;--ink-3:#7a9880;--ink-4:#4d6652;--rule:#e8f2ea1a;--rule-soft:#e8f2ea0f;--accent:oklch(65% .17 148);--accent-ink:oklch(78% .13 148);--accent-soft:#3c8c5033}*{box-sizing:border-box}html,body{background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;font-size:15px;line-height:1.5}.serif{font-family:var(--serif);letter-spacing:-.01em;font-weight:400}.sans{font-family:var(--sans)}.mono{font-family:var(--mono)}.eyebrow{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);font-size:10.5px;font-weight:500}.h-display{font-family:var(--serif);letter-spacing:-.02em;color:var(--ink);font-size:72px;font-weight:400;line-height:.98}.h-1{font-family:var(--serif);letter-spacing:-.015em;font-size:44px;font-weight:400;line-height:1.05}.h-2{font-family:var(--serif);letter-spacing:-.01em;font-size:28px;font-weight:400;line-height:1.15}.lead{font-family:var(--sans);color:var(--ink-2);font-size:17px;font-weight:400;line-height:1.5}.italic-serif{font-family:var(--serif);font-style:italic}.btn{height:44px;font-family:var(--sans);letter-spacing:-.005em;cursor:pointer;white-space:nowrap;border:none;border-radius:9999px;justify-content:center;align-items:center;gap:8px;padding:0 20px;font-size:14px;font-weight:500;transition:transform .12s,background .15s,box-shadow .15s;display:inline-flex}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--ink);color:var(--bg)}.btn-primary:hover{background:var(--ink-2)}.btn-accent{background:var(--accent);color:#fff;box-shadow:var(--shadow-sm), inset 0 1px 0 #ffffff2e}.btn-accent:hover{filter:brightness(1.06)}.btn-ghost{color:var(--ink-2);background:0 0}.btn-ghost:hover{background:var(--rule-soft);color:var(--ink)}.btn-outline{color:var(--ink);border:1px solid var(--rule);background:0 0}.btn-outline:hover{background:var(--bg-elev);border-color:#1f1b162e}.btn-sm{height:32px;padding:0 14px;font-size:13px}.btn-icon{width:36px;padding:0}.input{appearance:none;border:1px solid var(--rule);background:var(--bg-elev);width:100%;height:52px;color:var(--ink);font-family:var(--sans);border-radius:9999px;outline:none;padding:0 18px;font-size:15px;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.input::placeholder{color:var(--ink-4)}.surface{background:var(--bg-elev);border-radius:var(--r-lg);border:1px solid var(--rule-soft)}.divider{background:var(--rule);border:0;height:1px;margin:0}.divider-soft{background:var(--rule-soft);border:0;height:1px;margin:0}.ph{color:#0e1a108c;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;background:repeating-linear-gradient(135deg,#3c78461f 0 1px,#0000 1px 12px),linear-gradient(135deg,#cfe3d4 0%,#bdd5c5 100%);font-size:11px;position:relative;overflow:hidden}.ph-label{align-items:center;gap:6px;display:flex;position:absolute;inset:auto 12px 12px}.ph-label:before{content:"";background:#1f1b1666;border-radius:50%;width:6px;height:6px}.ph-sage{background:repeating-linear-gradient(135deg,#3d6b3a1a 0 1px,#0000 1px 12px),linear-gradient(135deg,#dde6d4 0%,#c9d8bd 100%)}.ph-cream{background:repeating-linear-gradient(135deg,#1f1b160f 0 1px,#0000 1px 12px),linear-gradient(135deg,#f0e8d8 0%,#e7dcc4 100%)}.ph-mocha{background:repeating-linear-gradient(135deg,#1f1b161a 0 1px,#0000 1px 12px),linear-gradient(135deg,#d9c4ad 0%,#b89878 100%)}.chip{background:var(--bg-deep);height:26px;color:var(--ink-2);font-family:var(--sans);border:1px solid var(--rule-soft);border-radius:9999px;align-items:center;gap:6px;padding:0 10px;font-size:12px;font-weight:500;display:inline-flex}.chip-accent{background:var(--accent-soft);color:var(--accent-ink);border-color:#0000}.check-row{border-bottom:1px solid var(--rule-soft);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:12px;padding:11px 0;display:flex}.check-row:last-child{border-bottom:none}.check-box{border:1.5px solid var(--ink-4);background:0 0;border-radius:50%;flex:0 0 18px;justify-content:center;align-items:center;width:18px;height:18px;transition:all .15s;display:flex}.check-row.checked .check-box{background:var(--accent);border-color:var(--accent)}.check-row.checked .check-text{color:var(--ink-4);text-decoration:line-through;-webkit-text-decoration-color:var(--ink-4);text-decoration-color:var(--ink-4);text-decoration-thickness:1px}.check-text{color:var(--ink);flex:1;transition:color .15s}.check-qty{color:var(--ink-3);font-variant-numeric:tabular-nums;white-space:nowrap;font-size:13.5px}.step-num{font-family:var(--serif);color:var(--accent);flex:none;width:44px;font-size:32px;font-style:italic;line-height:1}.density-compact .check-row{padding:7px 0}.density-comfy .check-row{padding:14px 0}.row{display:flex}.col{flex-direction:column;display:flex}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.gap-8{gap:32px}.gap-10{gap:40px}.center{justify-content:center;align-items:center}.between{justify-content:space-between}.items-center{align-items:center}.items-start{align-items:flex-start}.logo-mark{background:var(--ink);width:28px;height:28px;color:var(--bg);font-family:var(--serif);border-radius:8px;justify-content:center;align-items:center;font-size:19px;font-style:italic;font-weight:400;display:flex}.app-shell{background:var(--bg);min-height:100vh;color:var(--ink)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:2px solid var(--rule);border-top-color:var(--accent);border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.fade-up{animation:.4s both fadeUp}.no-scrollbar::-webkit-scrollbar{display:none}.no-scrollbar{scrollbar-width:none}.toast{background:var(--ink);color:var(--bg);z-index:100;pointer-events:none;border-radius:9999px;padding:10px 20px;font-size:13px;font-weight:500;animation:.25s both fadeUp;position:fixed;bottom:32px;left:50%;transform:translate(-50%)}.nav-link{appearance:none;cursor:pointer;font-family:var(--sans);color:var(--ink-3);background:0 0;border:1px solid #0000;border-radius:999px;align-items:center;gap:4px;padding:8px 14px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex}.nav-link:hover{color:var(--ink);background:var(--rule-soft)}.nav-link.active{color:var(--ink);background:var(--bg-elev);border-color:var(--rule)}.recipes-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;display:grid}.recipe-detail-grid{grid-template-columns:minmax(0,.9fr) minmax(0,1.4fr);gap:64px;display:grid}.recipe-card-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}@media (width<=1024px){.recipes-page{padding:28px 20px 80px!important}.recipes-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.recipe-detail-page{padding:20px 16px 80px!important}.recipe-detail-grid{grid-template-columns:1fr;gap:28px}.recipe-detail-ingredients{position:static!important}}@media (width<=768px){.recipes-header{flex-direction:column;align-items:flex-start!important;gap:14px!important;margin-bottom:20px!important}.recipes-controls{gap:10px!important;margin-bottom:18px!important}.recipes-search{flex:100%!important}.recipes-tags{flex:100%}.recipes-grid{grid-template-columns:1fr;gap:14px}.add-recipe-tile{min-height:200px!important}.recipe-detail-topbar{flex-direction:column;gap:10px;align-items:flex-start!important}.recipe-meta-row{grid-template-columns:1fr 1fr;display:grid!important}.recipe-meta-row>div{border-top:1px solid var(--rule);border-left:none!important}.recipe-meta-row>div:first-child,.recipe-meta-row>div:nth-child(2){border-top:none}.h-display{font-size:44px}.h-1{font-size:32px}.desktop-only{display:none!important}}@media (width>=769px){.mobile-only{display:none!important}}.bottom-tab-bar{display:none}.hero-grid{grid-template-columns:1.05fr .95fr;align-items:center;gap:80px;margin-bottom:88px;display:grid}.home-form{gap:8px;max-width:560px;display:flex}.how-it-works-grid{grid-template-columns:repeat(3,1fr);gap:32px;display:grid}.recipe-note{color:#78350f;background:#fff8e6;border-left:3px solid #f59e0b;border-radius:6px;margin-top:12px;margin-bottom:16px;padding:10px 14px;font-size:.85rem}.recipe-tabs{border-bottom:1px solid var(--rule-soft);padding:0 22px;display:flex}.recipe-tab{appearance:none;font-size:14px;font-weight:500;font-family:var(--sans);cursor:pointer;color:var(--ink-3);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;margin-right:22px;padding:12px 0}.recipe-tab.active{color:var(--ink);border-bottom-color:var(--accent)}.recently-saved{padding:0 0 24px 24px}.recently-saved-scroll{gap:12px;padding-right:24px;display:flex;overflow-x:auto}.recipe-mobile-bar{display:none}@media (width<=768px){.bottom-tab-bar{z-index:20;border-top:1px solid var(--rule-soft);background:var(--bg);padding-bottom:env(safe-area-inset-bottom,0px);display:flex;position:fixed;bottom:0;left:0;right:0}.hero-grid{grid-template-columns:1fr;gap:0;margin-bottom:40px}.home-form{flex-direction:column}.home-form .btn{border-radius:12px;width:100%;height:48px}.how-it-works-grid{grid-template-columns:1fr;gap:28px}.home-page{padding:28px 20px 96px!important}.recipes-grid{grid-template-columns:repeat(2,1fr)!important;gap:12px!important}.recipes-tags{overflow-x:auto;flex-wrap:nowrap!important}.recipes-tags>button{flex:none}.recipes-search{flex:100%!important}.recipe-mobile-bar{border-top:1px solid var(--rule-soft);background:var(--bg);z-index:5;flex-shrink:0;gap:8px;padding:12px 16px 16px;display:flex;position:sticky;bottom:0}}body.recipe-open .bottom-tab-bar{display:none!important}
