*{box-sizing:border-box}html,body,#root{height:100%}html{scroll-behavior:smooth}html,body{overscroll-behavior-y:contain}:root{--tabbar-height: 64px;--bg: #f8f6f0;--bg-2: #fdfcf9;--bg-3: #e8efe5;--panel: #ffffff;--card: #ffffff;--border: #e7e2d9;--text: #2f2f2f;--muted: #5b5b5b;--brand: #6bbf59;--brand-2: #4f9e42;--accent-terracotta: #d98466;--accent-sage: #87a97a;--accent-olive: #9fbf90;--accent-sand: #e4c590;--ok: #4f9e42;--warn: #e4c590;--err: #d98466}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";background:radial-gradient(1200px 800px at 0% 0%,var(--bg-2),transparent 70%),radial-gradient(1200px 800px at 100% 100%,var(--bg-3),transparent 70%),var(--bg);color:var(--text);background-size:200% 200%;animation:bg-slow 60s ease-in-out infinite alternate}@keyframes bg-slow{0%{background-position:0% 0%}to{background-position:100% 100%}}.player-open{overflow:hidden}.container{max-width:100%;margin:0 auto;padding:env(safe-area-inset-top) 16px env(safe-area-inset-bottom)}header.app-header{position:sticky;top:0;z-index:20;margin:0 0 16px;background:linear-gradient(90deg,#87a97a1a,#dfd2b31a);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}header .bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px}.brand{display:flex;align-items:center;gap:10px}.brand .logo{width:72px;height:72px;border-radius:10px;background:linear-gradient(135deg,var(--brand),var(--brand-2));box-shadow:0 6px 18px #4f9e4259}.brand h1{font-size:1.25rem;margin:0}.subtitle{color:var(--muted);margin-top:2px;font-size:.85rem}main{display:grid;gap:16px;padding-bottom:calc(var(--tabbar-height) + env(safe-area-inset-bottom))}.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:16px;box-shadow:0 8px 22px #0000000d}h1,h2,h3{font-family:Poppins,Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;letter-spacing:.2px}h1{font-size:1.75rem;margin:0;font-weight:600}h2{font-size:1.125rem;margin:0 0 8px;font-weight:600}.badge{display:inline-block;padding:6px 12px;border-radius:9999px;font-weight:700;border:1px solid transparent;text-decoration:none;transition:transform .2s ease-out,filter .2s ease-out}.badge.loading{background:#f8fafc;color:#334155;border-color:#e5e7eb}.badge.ok{background:#ecfdf5;color:#065f46;border-color:#a7f3d0}.badge.error{background:#fef2f2;color:#7f1d1d;border-color:#fecaca}.badge:hover{filter:brightness(1.07);transform:translateY(-1px)}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:9999px;font-weight:700;text-decoration:none;color:#fff;background:linear-gradient(135deg,var(--brand),var(--brand-2));box-shadow:0 10px 20px #4f9e4240;transition:transform .2s ease-out,box-shadow .2s ease-out,filter .2s ease-out;border:0;outline:none}.btn:hover{transform:translateY(-1px) scale(1.02);box-shadow:0 14px 26px #4f9e4247}.btn:focus,.btn:focus-visible{outline:none;box-shadow:0 0 0 3px #87a97a2e,0 10px 20px #4f9e4240}.btn.danger{color:#fee2e2;background:linear-gradient(135deg,#dc2626,#ef4444);box-shadow:0 10px 20px #ef444459;border:1px solid rgba(220,38,38,.6)}.btn:disabled{opacity:.7;cursor:not-allowed;filter:grayscale(.2)}.code{white-space:pre-wrap;word-break:break-word;background:var(--panel);padding:12px;border-radius:10px;border:1px solid var(--border)}.input,.select,.textarea{width:100%;color:var(--text);background:#fff;border:1px solid #dcd7cc;border-radius:12px;padding:10px 12px;transition:border-color .2s ease-out,box-shadow .2s ease-out,transform .2s ease-out}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--accent-sage);box-shadow:0 0 0 3px #87a97a2e}button:focus{outline:none}a:focus{outline:none}.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}footer{text-align:center;color:#64748b;padding:24px 0}.block{display:block}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-wrap{flex-wrap:wrap}.gap-2{gap:.5rem}.grid{display:grid}.relative{position:relative}.text-xs{font-size:.75rem;line-height:1rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-2xl{font-size:1.5rem;line-height:2rem}.font-semibold{font-weight:600}.text-gray-100{color:#111827}.text-gray-300{color:#1f2937}.text-gray-400{color:var(--muted)}.text-gray-500{color:#475569}.text-gray-900{color:var(--text)}.text-sky-400{color:#38bdf8}.text-sky-400:hover{color:#7dd3fc}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.space-y-2>*+*{margin-top:.5rem}.space-y-3>*+*{margin-top:.75rem}.tabbar{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-evenly;align-items:center;gap:4px;background:#fffffff2;border-top:1px solid var(--border);padding:8px 10px calc(8px + env(safe-area-inset-bottom));min-height:var(--tabbar-height);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);transform:translateZ(0);will-change:transform;contain:layout paint style}.player-open .tabbar{display:none!important}.player-open .btn:hover{transform:none!important;filter:none!important}.player-open .badge:hover{filter:none!important}.player-open .card:hover{transform:none!important;border-color:var(--border)!important;box-shadow:0 6px 16px #0206170f!important}.tab-item{text-align:center;text-decoration:none;color:#475569;padding:8px 6px;border-radius:10px}.tab-item.active{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;font-weight:700}.dropdown{position:absolute;width:100%;z-index:1000;background:var(--panel);border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 24px #0000001f;max-height:280px;overflow-y:auto}.dropdown-item{padding:8px 12px;cursor:pointer;border-radius:8px}.dropdown-item:hover,.dropdown-item.active{background:#f5efe3}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:none}.list-none{list-style:none;padding-left:0;margin-left:0}.dropdown-field{padding-right:30px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23bfae92' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}@keyframes pulse{0%{transform:scale(1)}40%{transform:scale(1.2)}to{transform:scale(1)}}button[aria-label][title*=Favourite]:active,button[aria-label][title*=Unfavourite]:active{animation:pulse .3s ease-out}.skeleton-card{border-radius:16px;border:1px solid var(--border);background:var(--panel);padding:12px}.skeleton-box{position:relative;overflow:hidden;background:#eee;border-radius:8px}.skeleton-box:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;transform:translate(-100%);background-image:linear-gradient(90deg,#fff0,#fff9,#fff0);animation:shimmer 1.2s infinite}@keyframes shimmer{to{transform:translate(100%)}}@keyframes recipe-appear{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.recipe-appear{opacity:0;animation:recipe-appear .28s ease-out both;animation-delay:var(--stagger, 0ms);will-change:transform,opacity}.image-placeholder{width:100%;height:120px;border-radius:8px;display:grid;place-items:center;padding:8px;text-align:center;color:#fff;font-weight:700;background:linear-gradient(135deg,var(--brand),var(--brand-2));box-shadow:0 6px 18px #4f9e422e;margin-bottom:8px}.image-placeholder .placeholder-title{padding:6px 10px;font-size:1rem;line-height:1.2;word-break:break-word}.image-placeholder.large{height:320px;border-radius:12px;font-size:1.25rem}.favorite-icon:hover{transform:scale(1.15);filter:brightness(1.1)}.favorite-icon:active{transform:scale(.95)}
