*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Arial,sans-serif;background:#f6f6f7;color:#111}
.container{max-width:1100px;margin:0 auto;padding:16px}
.bar{position:sticky;top:0;background:#fff;border-bottom:1px solid #e5e7eb}
.row{display:flex;align-items:center}.gap{gap:8px}.between{justify-content:space-between}.end{justify-content:flex-end}.ml-auto{margin-left:auto}.align-center{align-items:center}
.grid{display:grid;grid-template-columns:1fr 360px;gap:16px}
@media (max-width: 960px){.grid{grid-template-columns:1fr}}
.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:14px;box-shadow:0 1px 2px rgba(0,0,0,.03)}
.ingredients{margin:6px 0 0 0;padding-left:18px;color:#555}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin:6px 0}
.tags span{font-size:11px;background:#f1f5f9;border:1px solid #e2e8f0;padding:2px 6px;border-radius:999px}
.dropzone{background:#fff;border:2px dashed #cbd5e1;border-radius:14px;padding:12px}
.cart-list{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:8px}
.cart-item{display:flex;gap:8px;align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:8px}
.cart-item .title{flex:1}
.shopping-list{list-style:none;margin:8px 0 0;padding:0;display:grid;grid-template-columns:1fr;gap:6px}
.btn{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:8px 10px;text-decoration:none;color:#111;cursor:pointer}
.btn:hover{background:#f8fafc}
.btn.primary{background:#2563eb;color:#fff;border-color:#2563eb}
.btn.danger{background:#fee2e2;border-color:#fecaca}
.btn.small{padding:4px 8px;font-size:12px}
.input{width:100%;padding:8px 10px;border:1px solid #e5e7eb;border-radius:10px;background:#fff}
.field{display:flex;flex-direction:column;gap:6px;margin:8px 0}
.alert{background:#fef3c7;border:1px solid #fde68a;color:#92400e;border-radius:10px;padding:10px;margin:12px 0}
.grid-ings{display:grid;grid-template-columns:1fr 120px 120px 60px;gap:8px;margin:8px 0}
.grid-ings.head>div{font-size:12px;color:#6b7280}
.muted{color:#6b7280;font-size:14px}
