*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #f97316;--primary-dk: #ea6a0a;--bg: #fafaf9;--surface: #ffffff;--border: #e7e5e4;--text: #1c1917;--muted: #78716c;--danger: #ef4444;--radius: 12px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);--nav-h: 60px}html{height:100%;font-size:16px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);min-height:100%;-webkit-font-smoothing:antialiased}#root{max-width:480px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;position:relative}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-radius:var(--radius);font-size:.95rem;font-weight:600;border:none;cursor:pointer;transition:background .15s,transform .1s;-webkit-tap-highlight-color:transparent}.btn:active{transform:scale(.97)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dk)}.btn-ghost{background:transparent;color:var(--text)}.btn-ghost:hover{background:var(--border)}.btn-danger{background:var(--danger);color:#fff}.btn-full{width:100%}.btn-sm{padding:6px 14px;font-size:.85rem}.btn-icon{padding:8px;border-radius:50%;aspect-ratio:1}input,textarea,select{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:8px;font-size:.95rem;background:var(--surface);color:var(--text);outline:none;transition:border-color .15s;font-family:inherit}input:focus,textarea:focus,select:focus{border-color:var(--primary)}textarea{resize:vertical;min-height:80px}.card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;height:var(--nav-h);background:var(--surface);border-top:1px solid var(--border);display:flex;align-items:stretch;z-index:100}.bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;text-decoration:none;color:var(--muted);font-size:.72rem;font-weight:500;transition:color .15s;-webkit-tap-highlight-color:transparent}.bottom-nav a.active,.bottom-nav a:hover{color:var(--primary)}.bottom-nav svg{width:22px;height:22px}.page{flex:1;padding:16px 16px calc(var(--nav-h) + 16px);overflow-y:auto}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.page-header h1{font-size:1.4rem;font-weight:700}.recipe-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.recipe-card{cursor:pointer}.recipe-card img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}.recipe-card-body{padding:10px 12px 12px}.recipe-card-title{font-size:.9rem;font-weight:600;line-height:1.3}.recipe-card-meta{font-size:.78rem;color:var(--muted);margin-top:4px}.loader{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--muted)}.toast{position:fixed;bottom:calc(var(--nav-h) + 16px);left:50%;transform:translate(-50%);background:#1c1917;color:#fff;padding:10px 20px;border-radius:24px;font-size:.88rem;font-weight:500;z-index:999;animation:fadeUp .2s ease}@keyframes fadeUp{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.fab{position:fixed;bottom:calc(var(--nav-h) + 16px);right:16px;width:52px;height:52px;border-radius:50%;border:none;background:var(--primary);color:#fff;font-size:1.6rem;line-height:1;box-shadow:0 4px 12px #f9731666;cursor:pointer;z-index:50;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .1s;-webkit-tap-highlight-color:transparent}.fab:active{transform:scale(.93)}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.85rem;font-weight:600;color:var(--muted)}.form-section{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.form-section h2{font-size:1rem;font-weight:700;border-bottom:1px solid var(--border);padding-bottom:8px}.pill{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:99px;background:#fff7ed;color:var(--primary);font-size:.78rem;font-weight:600}.ing-row{display:grid;grid-template-columns:1fr 70px 80px auto;gap:8px;align-items:center}.ing-row .remove-btn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:1.1rem;padding:4px;border-radius:4px}.ing-row .remove-btn:hover{color:var(--danger)}.shop-section{margin-bottom:20px}.shop-section h3{font-size:.85rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.shop-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.shop-item:last-child{border-bottom:none}.shop-item input[type=checkbox]{width:20px;height:20px;accent-color:var(--primary);flex-shrink:0}.shop-item.checked span{text-decoration:line-through;color:var(--muted)}.shop-item span{font-size:.95rem;flex:1}.shop-item .qty{font-size:.85rem;color:var(--muted);white-space:nowrap}
