*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:oklch(0.145 0.005 285);--bg-2:oklch(0.175 0.006 285);--card:oklch(0.205 0.007 285);--card-2:oklch(0.235 0.008 285);--border:oklch(0.275 0.008 285);--border-soft:oklch(0.235 0.008 285);--muted:oklch(0.71 0.015 285);--muted-2:oklch(0.55 0.013 285);--fg:oklch(0.985 0.002 285);--primary:oklch(0.985 0.002 285);--primary-fg:oklch(0.21 0.006 285);--accent:oklch(0.78 0.155 70);--accent-soft:oklch(0.78 0.155 70/0.14);--green:oklch(0.78 0.16 155);--green-soft:oklch(0.78 0.16 155/0.14);--red:oklch(0.72 0.18 25);--red-soft:oklch(0.72 0.18 25/0.14);--blue:oklch(0.74 0.13 245);--purple:oklch(0.75 0.14 305);--shadow:0 1px 0 0 rgb(255 255 255/0.04) inset,0 1px 2px rgb(0 0 0/0.5);--shadow-lg:0 20px 40px -12px rgb(0 0 0/0.6),0 8px 16px -8px rgb(0 0 0/0.4);--r-sm:8px;--r:12px;--r-lg:16px;--r-xl:22px;--bg2:var(--bg-2);--surface:var(--card);--surface2:var(--card-2);--border2:var(--border-soft);--text:var(--fg);--muted2:var(--muted-2);--accent-fg:var(--primary-fg);--red-dim:var(--red-soft);--red-border:color-mix(in oklch,var(--red),transparent 70%);--sh-md:var(--shadow)}body,html{height:100%;background:#06060a;color:var(--fg);font-family:Geist,-apple-system,system-ui,sans-serif;font-size:14px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{overflow:hidden}.mono{font-family:Geist Mono,ui-monospace,Menlo,monospace}.app{position:fixed;top:0;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:480px;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.app h1{font-size:24px;font-weight:600;letter-spacing:-.025em;line-height:1.15}.app h2{font-size:20px;font-weight:600;letter-spacing:-.02em}.app h3{font-size:15px;font-weight:600;letter-spacing:-.01em}.app p{font-size:13.5px;color:var(--muted);line-height:1.55}.scroll{flex:1 1;overflow-y:auto;overflow-x:hidden;padding-bottom:100px}.scroll::-webkit-scrollbar{display:none}.topbar{padding:10px 18px 12px;display:flex;align-items:flex-end;justify-content:space-between;gap:8px;background:linear-gradient(to bottom,var(--bg) 70%,color-mix(in oklch,var(--bg),transparent 0%));position:-webkit-sticky;position:sticky;top:0;z-index:20;min-height:70px}.topbar-greet{font-size:11.5px;color:var(--muted-2);margin-bottom:3px;letter-spacing:.005em}.topbar-title{font-size:19px;font-weight:600;letter-spacing:-.02em;white-space:nowrap}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;cursor:pointer;font-family:inherit;font-size:13px;font-weight:500;letter-spacing:-.005em;display:inline-flex;align-items:center;justify-content:center;gap:6px;height:36px;padding:0 14px;border-radius:10px;transition:transform .12s ease,background .15s ease,opacity .15s ease,box-shadow .15s ease}.btn:active{transform:scale(.97)}.btn-primary{background:var(--primary);color:var(--primary-fg);box-shadow:inset 0 1px 0 0 rgb(255 255 255/.4),0 1px 2px rgb(0 0 0/.3)}.btn-primary:hover{opacity:.92}.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}.btn-ghost:hover,.btn-secondary{background:var(--card);color:var(--fg)}.btn-secondary{border:1px solid var(--border)}.btn-secondary:hover{background:var(--card-2)}.btn-danger{background:var(--red-soft);color:var(--red);border:1px solid color-mix(in oklch,var(--red),transparent 70%)}.btn-icon{width:36px;height:36px;padding:0;border-radius:10px;background:var(--card);color:var(--muted);border:1px solid var(--border)}.btn-icon:hover{color:var(--fg)}.btn-icon.active{background:var(--accent-soft);color:var(--accent);border-color:color-mix(in oklch,var(--accent),transparent 70%)}.btn-lg{height:44px;padding:0 18px;font-size:14px;border-radius:12px}.btn-full{width:100%}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg)}.card-soft{background:var(--bg-2);border:1px solid var(--border-soft);border-radius:var(--r-lg)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:500;border-radius:99px;background:var(--card-2);border:1px solid var(--border);color:var(--muted);letter-spacing:-.005em}.badge-accent{background:var(--accent-soft);color:var(--accent);border-color:color-mix(in oklch,var(--accent),transparent 70%)}.badge-green{background:var(--green-soft);color:var(--green);border-color:color-mix(in oklch,var(--green),transparent 70%)}.badge-red{background:var(--red-soft);color:var(--red);border-color:color-mix(in oklch,var(--red),transparent 70%)}.tabs{background:var(--bg-2);border:1px solid var(--border-soft);padding:3px;border-radius:12px;gap:2px;width:100%}.tab,.tabs{display:inline-flex}.tab{flex:1 1;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;cursor:pointer;background:transparent;color:var(--muted-2);font-family:inherit;font-size:12.5px;font-weight:500;height:30px;border-radius:9px;transition:all .18s ease;align-items:center;justify-content:center;gap:5px}.tab.active{background:var(--card-2);color:var(--fg);box-shadow:inset 0 1px 0 0 rgb(255 255 255/.04),0 1px 2px rgb(0 0 0/.3)}.input{width:100%;background:var(--bg-2);border:1px solid var(--border);color:var(--fg);height:40px;padding:0 12px;border-radius:10px;font-family:inherit;font-size:13.5px;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.input:focus{border-color:color-mix(in oklch,var(--fg),transparent 50%);box-shadow:0 0 0 3px color-mix(in oklch,var(--fg),transparent 90%)}.input::placeholder{color:var(--muted-2)}.search{position:relative}.search .input{padding-left:36px}.search svg{position:absolute;top:50%;left:12px;transform:translateY(-50%);color:var(--muted-2)}.botnav{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);z-index:60;height:60px;width:calc(100% - 24px);background:color-mix(in oklch,var(--card),transparent 15%);backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);border:1px solid var(--border);border-radius:22px;display:flex;align-items:center;padding:0 6px;box-shadow:0 12px 30px -10px rgba(0,0,0,.5)}.botnav-item{flex:1 1;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;cursor:pointer;background:transparent;color:var(--muted-2);height:48px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;gap:6px;font-family:inherit;font-size:12px;font-weight:500;position:relative;transition:color .2s ease,background .2s ease}.botnav-item.active{color:var(--primary-fg);background:var(--fg)}.botnav-item .label{display:none}.botnav-item.active .label{display:inline}.fab{position:absolute;bottom:88px;right:16px;z-index:70;width:52px;height:52px;border-radius:18px;background:var(--accent);color:oklch(.18 .02 70);border:0;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 12px 28px -10px color-mix(in oklch,var(--accent),transparent 50%),0 1px 0 0 rgb(255 255 255/.4) inset;cursor:pointer;transition:transform .15s ease}.fab:active{transform:scale(.94)}.recipe-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;cursor:pointer;transition:transform .15s ease,border-color .2s ease}.recipe-card:hover{border-color:color-mix(in oklch,var(--border),white 10%)}.recipe-card:active{transform:scale(.985)}.recipe-img{position:relative;height:130px;overflow:hidden}.recipe-img>.img{position:absolute;inset:0;background-size:cover;background-position:50%}.recipe-img>.img:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.55),transparent 50%)}.recipe-img .fav-btn{position:absolute;top:10px;right:10px;width:32px;height:32px;border-radius:10px;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12);display:inline-flex;align-items:center;justify-content:center;color:rgba(255,255,255,.8);cursor:pointer}.recipe-img .fav-btn.on{color:var(--red);background:rgba(0,0,0,.6)}.recipe-img .meta-overlay{position:absolute;left:10px;bottom:10px;right:10px;display:flex;gap:6px;flex-wrap:wrap}.recipe-body{padding:12px 14px 14px}.recipe-title{font-size:15px;font-weight:600;letter-spacing:-.01em;margin-bottom:4px}.recipe-desc{font-size:12px;color:var(--muted-2);line-height:1.4;display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.recipe-meta{display:flex;align-items:center;gap:12px;margin-top:10px;color:var(--muted-2);font-size:11.5px}.recipe-meta span{display:inline-flex;align-items:center;gap:4px}.placeholder-1{background:repeating-linear-gradient(135deg,oklch(.32 .06 30) 0 12px,oklch(.28 .05 30) 12px 24px)}.placeholder-2{background:repeating-linear-gradient(135deg,oklch(.34 .06 80) 0 12px,oklch(.3 .05 80) 12px 24px)}.placeholder-3{background:repeating-linear-gradient(135deg,oklch(.32 .06 145) 0 12px,oklch(.28 .05 145) 12px 24px)}.placeholder-4{background:repeating-linear-gradient(135deg,oklch(.32 .06 250) 0 12px,oklch(.28 .05 250) 12px 24px)}.placeholder-5{background:repeating-linear-gradient(135deg,oklch(.32 .06 305) 0 12px,oklch(.28 .05 305) 12px 24px)}.placeholder-6{background:repeating-linear-gradient(135deg,oklch(.3 .05 0) 0 12px,oklch(.26 .04 0) 12px 24px)}.chips{display:flex;gap:6px;padding:4px 18px 12px;overflow-x:auto}.chips::-webkit-scrollbar{display:none}.chip{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border);background:var(--card);color:var(--muted);height:32px;padding:0 12px;border-radius:99px;font-family:inherit;font-size:12.5px;font-weight:500;cursor:pointer;white-space:nowrap;display:inline-flex;align-items:center;gap:6px;transition:all .18s ease}.chip.active{background:var(--fg);color:var(--primary-fg);border-color:var(--fg)}@keyframes slidein-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadein{0%{opacity:0}to{opacity:1}}@keyframes pulse-dot{0%,to{opacity:.5}50%{opacity:1}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes heart-pop{0%{transform:scale(1)}30%{transform:scale(1.35)}60%{transform:scale(.92)}to{transform:scale(1)}}.stagger>*{animation:slidein-up .42s cubic-bezier(.32,.72,0,1) both}.stagger>:first-child{animation-delay:.04s}.stagger>:nth-child(2){animation-delay:.1s}.stagger>:nth-child(3){animation-delay:.16s}.stagger>:nth-child(4){animation-delay:.22s}.stagger>:nth-child(5){animation-delay:.28s}.stagger>:nth-child(6){animation-delay:.34s}.stagger>:nth-child(7){animation-delay:.4s}.hero{position:relative;height:240px;overflow:hidden}.hero .img{background-size:cover;background-position:50%;transform:scale(1.05)}.hero .img,.hero:after{position:absolute;inset:0}.hero:after{content:"";background:linear-gradient(to bottom,rgba(0,0,0,.4) 0,transparent 30%,transparent 50%,var(--bg) 100%)}.hero-actions{position:absolute;top:56px;left:12px;right:12px;z-index:5;display:flex;justify-content:space-between}.hero-glass{width:38px;height:38px;border-radius:12px;background:rgba(0,0,0,.4);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.1);display:inline-flex;align-items:center;justify-content:center;color:var(--fg);cursor:pointer}.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:8px;gap:8px;margin:16px 18px 0}.stat{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:10px 12px;text-align:left}.stat-label{font-size:11px;color:var(--muted-2);margin-bottom:4px;letter-spacing:.01em}.stat-val{font-size:15px;font-weight:600;letter-spacing:-.01em}.ing-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border-soft);cursor:pointer}.ing-row:last-child{border-bottom:0}.ing-check{width:22px;height:22px;border-radius:7px;border:1.5px solid var(--border);background:var(--bg-2);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease}.ing-check.on{background:var(--green);border-color:var(--green);color:oklch(.18 .02 155)}.ing-name{flex:1 1;font-size:13.5px}.ing-name.done{color:var(--muted-2);text-decoration:line-through}.ing-amount{font-size:12.5px;color:var(--muted-2);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.ing-amount.done{text-decoration:line-through}.step-row{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--border-soft)}.step-row:last-child{border-bottom:0}.step-num{width:28px;height:28px;border-radius:99px;background:var(--bg-2);border:1px solid var(--border);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;font-size:12px;font-weight:600;color:var(--muted)}.step-row.active .step-num{background:var(--accent);color:oklch(.18 .02 70);border-color:var(--accent)}.step-text{font-size:13.5px;line-height:1.55;flex:1 1;padding-top:4px}.sheet-back{position:absolute;inset:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:200;animation:fadein .2s ease both}.sheet{position:absolute;left:0;right:0;bottom:0;z-index:210;background:var(--card);border-top-left-radius:28px;border-top-right-radius:28px;border-top:1px solid var(--border);padding:8px 18px calc(20px + 8px);animation:sheetup .32s cubic-bezier(.32,.72,0,1) both;max-height:80%;overflow-y:auto}.sheet-handle{width:36px;height:4px;background:var(--border);border-radius:99px;margin:8px auto 14px}.sheet-title{font-size:16px;font-weight:600;margin-bottom:14px;letter-spacing:-.01em}@keyframes sheetup{0%{transform:translateY(100%)}to{transform:translateY(0)}}.avatar{border-radius:12px;display:inline-flex;align-items:center;justify-content:center;color:white;font-weight:600;font-size:13px;flex-shrink:0}.tweaks{position:fixed;right:16px;bottom:16px;z-index:500;width:280px;background:oklch(.16 .005 285/.96);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:16px;padding:14px;color:var(--fg);font-family:Geist,sans-serif;display:none;box-shadow:0 20px 50px -10px rgba(0,0,0,.6)}.tweaks.open{display:block}.tweaks-title{font-size:12px;font-weight:600;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;margin-bottom:10px}.tweaks .row,.tweaks-title{display:flex;justify-content:space-between;align-items:center}.tweaks .row{padding:8px 0;font-size:12.5px}.tweaks .swatches{display:flex;gap:6px}.swatch{width:22px;height:22px;border-radius:7px;cursor:pointer;border:1px solid var(--border);transition:transform .12s ease}.swatch:hover{transform:scale(1.1)}.swatch.on{box-shadow:0 0 0 2px var(--fg)}.toggle{width:38px;height:22px;background:var(--card-2);border:1px solid var(--border);border-radius:99px;position:relative;cursor:pointer;transition:background .2s ease}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:var(--fg);border-radius:99px;transition:transform .2s ease}.toggle.on{background:var(--accent);border-color:var(--accent)}.toggle.on:after{transform:translateX(16px);background:oklch(.18 .02 70)}.progress{height:4px;background:var(--border-soft);border-radius:99px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:99px;transition:width .35s ease}.toast{position:absolute;top:60px;left:50%;transform:translateX(-50%);z-index:300;padding:10px 14px;background:var(--card);border:1px solid var(--border);border-radius:12px;font-size:12.5px;font-weight:500;color:var(--fg);display:inline-flex;gap:8px;align-items:center;box-shadow:var(--shadow-lg);animation:pop .25s cubic-bezier(.32,.72,0,1) both}.toast.success{border-color:color-mix(in oklch,var(--green),transparent 60%)}.toast.success .dot{width:8px;height:8px;border-radius:99px;background:var(--green)}.confirm-wrap{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;padding:16px}.confirm-box{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px;max-width:320px;width:100%;text-align:center;animation:pop .2s cubic-bezier(.32,.72,0,1)}@keyframes pop{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}.confirm-title{font-size:16px;font-weight:700;margin-bottom:8px}.confirm-msg{font-size:13px;color:var(--muted);line-height:1.5;margin-bottom:20px}.confirm-btns{display:flex;gap:8px}.confirm-btns button{flex:1 1;padding:11px;border-radius:10px;font-family:inherit;font-size:13px;font-weight:600;border:none;cursor:pointer}.confirm-cancel{background:var(--surface2);color:var(--text)}.confirm-ok{background:var(--red);color:white}.login-wrap{min-height:100svh;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:var(--bg)}.login-card{width:100%;max-width:360px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px 24px;box-shadow:var(--sh-md)}.login-brand{display:flex;flex-direction:column;align-items:center;margin-bottom:28px}.login-logo{font-size:40px;margin-bottom:10px}.login-title{font-size:22px;font-weight:700;letter-spacing:-.03em}.login-sub{font-size:13px;color:var(--muted);margin-top:4px}.login-btn{width:100%;padding:12px;background:var(--accent);color:var(--accent-fg);border:none;border-radius:9px;font-family:inherit;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:4px;transition:opacity .15s}.login-btn:hover{opacity:.92}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-error{margin-top:10px;padding:9px 11px;background:var(--red-dim);border:1px solid var(--red-border);border-radius:8px;color:var(--red);font-size:13px}.search-wrap{position:relative}.search-wrap input{padding-left:36px}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--muted2);pointer-events:none}.member-row{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border2)}.member-row:last-child{border-bottom:none}.member-avatar{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:white;flex-shrink:0}.role-badge{padding:1px 7px;border-radius:5px;font-size:10px;font-weight:600}.role-badge.owner{background:var(--yellow-dim,rgba(251,191,36,.12));color:var(--yellow);border:1px solid rgba(251,191,36,.25)}.role-badge.admin{background:var(--purple-dim);color:var(--purple);border:1px solid rgba(167,139,250,.25)}.role-badge.editor{background:var(--blue-dim);color:var(--blue);border:1px solid var(--blue-border)}.role-badge.viewer{background:var(--surface2);color:var(--muted);border:1px solid var(--border)}.cook-header{background:var(--surface);border-bottom:1px solid var(--border);padding:14px 16px}.cook-prog-label{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-bottom:6px}.cook-tabs{display:flex;gap:2px;margin-top:12px}.cook-tab{flex:1 1;padding:8px 0;border:none;border-radius:7px;font-family:inherit;font-size:13px;font-weight:500;color:var(--muted);background:none;cursor:pointer;transition:all .15s}.cook-tab.active{background:var(--surface2);color:var(--text)}.page{flex:1 1;overflow-y:auto;padding:16px 16px 100px}.page::-webkit-scrollbar{display:none}.section-hdr{font-size:11px;font-weight:600;color:var(--muted-2);letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px;margin-top:4px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:12px;font-weight:500;color:var(--muted)}.field input,.field select,.field textarea{width:100%;background:var(--bg-2);border:1px solid var(--border);color:var(--fg);height:40px;padding:0 12px;border-radius:10px;font-family:inherit;font-size:13.5px;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.field textarea{height:auto;padding:10px 12px;resize:vertical}.field input:focus,.field textarea:focus{border-color:color-mix(in oklch,var(--fg),transparent 50%);box-shadow:0 0 0 3px color-mix(in oklch,var(--fg),transparent 90%)}.field input::placeholder,.field textarea::placeholder{color:var(--muted-2)}.spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--muted);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(1turn)}}.empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:48px 24px;color:var(--muted-2)}.empty-icon{margin-bottom:14px;opacity:.5}.empty-title{font-size:15px;font-weight:600;color:var(--muted);margin-bottom:6px}.empty-sub{font-size:13px;color:var(--muted-2);line-height:1.5;max-width:26ch}